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esde hace unos pocos meses ha crecido expo¬ 
nencialmente el interés del mundo científico y 
del campo de la informática por un conjunto de 
técnicas y teorías conocidas como Inteligencia 
Artificial. ¿Cuáles son las causas que han moti¬ 
vado el enorme auge de esta nueva disciplina? 

Desde luego, el intento de construir máqui¬ 
nas que presenten las capacidades que asocia¬ 
mos con la inteligencia humana no es nada re- 
ya en el siglo xvm se construyeron los primeros autómatas 
que intentaban emular aspectos parciales. La causa del relanza¬ 
miento de la I.A. provino de la falta de algoritmos matemáticos ca¬ 
paces de enfrentarse a situaciones aparentemente sencillas, tales 
como el reconocimiento del lenguaje, los problemas de diagno¬ 
sis (enfermedades, geológicos) o el reconocimiento visual de 
objetos.. 

El término Inteligencia Artificial se presta en cierta medida a 
interpretaciones erróneas y, tal y como ocurrió con los "Cerebros 
Electrónicos"; quizá dentro de unos pocos años esta denomina¬ 
ción haya desaparecido y surjan otros términos más acordes con 
la realidad de las investigaciones. 

Hoy en día los programas más avanzados son más sistemas 
basados en el conocimiento de expertos que sistemas inteligen¬ 
tes, ya que sus capacidades son, aunque de una cierta potencia, 
muy limitados en sus aplicaciones, restringiéndose a temas muy 
concretos. Tales son los ya muy famosos sistemas de diagnosis 
de enfermedades infecciosas o de prospecciones geológicas, que 
están siendo aplicados con mucho éxito por numerosos hospita¬ 
les y por las compañías petrolíferas. 
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El resultado de unir el conocimiento de un experto con los or¬ 
denadores más potentes y rápidos está creando un nuevo entor¬ 
no que cambiará completamente las estrategias de resolución de 
problemas antiguos y además permitirá enfrentarse a otros intra¬ 
tables en la actualidad. En todos aquellos problemas donde par¬ 
tiendo de unas combinaciones iniciales el sistema se expanda de 
una forma exponencial, el ordenador, por rápido y potente que 
fuera, nunca iría por delante de la creciente complejidad del mo¬ 
delo y, como resultado, las soluciones siempre serían parciales. In¬ 
corporar un conocimiento, una heurística, que permita al progra¬ 
ma eliminar aquellos caminos cuya posibilidad de ser correctos 
es más baja, facilitará la resolución de estas situaciones e impul¬ 
sará el esclarecimiento de numerosas cuestiones. 

La Inteligencia Artificial está siendo considerada por numero¬ 
sos países uno de los aspectos clave del progreso en los próxi¬ 
mos años. Dentro de estos países hay que citar, por su importan¬ 
cia, el Japón, que ha incluido de manera preferente los tres cam¬ 
pos de la I.A. (sistemas expertos, robótica y lenguaje natural) en 
el conjunto de temas a investigar dentro de los planes de la quin¬ 
ta generación de ordenadores. 

Es, por tanto, importante que el lector vaya teniendo una idea 
general sobre las perspectivas y limitaciones que nacen con la 
irrupción de la Inteligencia Artificial en el sector informático en ge¬ 
neral y pueda iniciarse en otra de las ramas de conocimiento que 
se abren a nuestros ojos. 
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INTRODUCCION A LA INTELIGENCIA ARTIFICIAL 


esde el inicio de la era de los ordenadores, los 
especialistas en informática han tratado de des- 
sarrollar técnicas que permitan a las computa¬ 
doras actuar como lo hace el ser humano. Una 
de las bases de apoyo de esta nueva forma de 
diseñar un programa es la Inteligencia Artificial. 

Se conoce como Inteligencia Artificial una 
nueva forma de resolver problemas dentro de 
los cuales se incluyen los sistemas expertos, el 
y control de robots y los procesadores de lenguaje natural, 
conjunto de las técnicas de la I.A. se están aplicando re¬ 
cientemente en la construcción de sistemas expertos, que permi¬ 
ten a los ordenadores ayudar al hombre a resolver .problemas y 
en la toma de decisiones. 

Esta nueva forma de enfrentarse a los problemas va a produ¬ 
cir en los próximos años una revolución dentro de la naciente re¬ 
lación entre el usuario y el ordenador, comparable a la introduc¬ 
ción de los microordenadores en todas las oficinas y hogares. Por 
una parte ayudará a la resolución de situaciones que antes, por su 
complejidad, eran casi imposibles de tratar mediante la progra¬ 
mación tradicional, y por otra, racionalizará y clarificará la infor¬ 
mación accesible al usuario, es decir, resumirá y simplificará la in¬ 
formación, destacando sólo aquella que es realmente importante 
para las necesidades del usuario. 

Considere, por ejemplo, el problema de diseñar un programa 
de entrenamiento para el personal de ventas de una empresa, don¬ 
de los productos y servicios de cara al cliente están cambiando 
constantemente. Se puede enseñar la técnica de ventas en gene¬ 
ral, pero los aspectos específicos de cada producto seguramente 
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habrán cambiado al tiempo de terminar el curso. Imagine en lu¬ 
gar de esto un programa capaz de interaccionar con el vendedor 
haciéndole preguntas y recomendándole las opciones apropiadas: 
sería igual que tener para cada vendedor un especialista puesto 
al día constantemente sobre los nuevos productos. El programa 
contará con un sistema asequible y sencillo que permita modifi¬ 
car la información que maneja y renovarla constantemente; ade¬ 
más, el cambio del programa será realizado por los especialistas 
del producto en la empresa y no será necesaria la intervención 
de un programador de ordenadores. Este es un ejemplo posible 
de lo que llegará en los próximos años. 

Pronto aparecerán también puestos de información inteligen¬ 
tes dentro de cada departamento de las fábricas, capaces de ma¬ 
nejar más datos y de forma más compleja que los actuales orde¬ 
nadores. La utilización de estos terminales por parte de los jefes 
de departamento o sección les permitirá controlar más activida¬ 
des y de una forma más ordenada, lo que redundará en el incre¬ 
mento de la cantidad y calidad de las decisiones que pueda tomar. 

Estas posibilidades que se vislumbran están llevando a la ma¬ 
yoría de las grandes empresas de todo el mundo a crear depar¬ 
tamentos de investigación en el campo de la I.A. y a rescatar de 
las universidades el conocimiento sobre los sistemas expertos que 
éstas poseen y que han venido elaborando desde la década de 
los años sesenta. El salto de las universidades a la industria lleva 
consigo que el mercado de las aplicaciones de LA. esté empezan¬ 
do a expandirse; los primeros resultados prácticos se están co¬ 
mercializando ya en los países más avanzados (Estados Unidos Ja¬ 
pón, Francia e Inglaterra). 


La génesis de la Inteligencia Artificial 

A finales de la segunda guerra mundial aparecieron en esce¬ 
na los primeros grupos de investigación que intentaban desarro¬ 
llar una máquina capaz de manejar de forma automática datos y 
números y llevar a cabo complejas operaciones matemáticas. Den¬ 
tro de ellos se podían distinguir dos tendencias: por una parte, 
aquellos que pensaban que las instrucciones fundamentales de 
funcionamiento de una máquina de tales características debían ser 
los operadores lógicos "AND", "OR", "NOT", y, por otra, aquellos 
que veían mucho más ventajoso (aunque menos potente en sus 
realizaciones) utilizar los operadores numéricos ">’',••• 

En aquellos tiempos la lentitud y capacidad de los primitivos 
ordenadores hizo que se diseñaran y construyeran en base a los 
operadores matemáticos, que poseen una capacidad de manejar 
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M .Figura 1.—Consola interactiva de un proceso industrial. El operario 
puede modificar e intervenir desde ¡a consola en el proceso que 
controla. 
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números muy buena, aunque fallan bastante en el manejo de la 

lógica. , , , 

Con el paso de los años los grupos de investigación basados 
en los operadores lógicos fueron abriéndose camino dentro de las 
universidades y dando los primeros pasos en lo que hoy llama¬ 
mos I.A. El camino fue largo y costoso, ya que los resultados ob¬ 
tenidos consistían en sistemas lentos en la ejecución y el produc¬ 
to final no era lo suficientemente práctico. Finalmente, y debido a 
un factor externo como es el desarrollo de la microelectrónica, 
que impulsó la construcción de una nuéva generación de orde¬ 
nadores de mayor capacidad, y a su rapidez y menor coste, se ha 
provisto a la Inteligencia Artificial del hardware apropiado a sus 
necesidades. . „ , 

Tradicionalmente se divide la Inteligencia Artificial en tres 
grandes aplicaciones: los procesados de lenguaje natural que fa¬ 
cilitan la comunicación del ordenador con el usuario, la robótica 
y todo lo asociado con la visión y manipulación de objetos y los 
sistemas expertos, basados en el almacenamiento del conocimien¬ 
to de un experto. , , , , 

Se puede apreciar en la figura 2 la cronología y los distintos 
factores que han impulsado las técnicas de la I.A. y los resultados 
que se esperan en los próximos años. 

Todos estos factores que se han comentado anteriormente no 
hubieran podido, sin embargo, atraer la atención de las grandes 
empresas y del mercado informático en general si no fuera por 
la aparición de nuevos retos a los que se están enfrentando las em¬ 
presas del sector informático. Uno de estos retos, y quizá el más 
importante, es la simulación de circunstancias y problemas reales. 

La simulación en un ordenador de una situación real, por pe¬ 
queña y sencilla que parezca, sólo es posible cuando las solucio¬ 
nes o estructuras en las que se expande el problema son pocas; 
a este tipo de problemas se les conoce como de explosión com¬ 
binatoria En aquellos casos donde las combinaciones son muchas, 
el ordenador, por grande y rápido que sea, nunca superará la com¬ 
plejidad del modelo. 

La solución no es, como se intuye, hacer más potente al or¬ 
denador. En vez de generar todas las soluciones o estructuras po¬ 
sibles, el programa sólo generará aquellas cuya posibilidad de sei 
ciertas es más alta. Consideremos el caso de un problema de aje¬ 
drez. ¿Cómo es posible que con todos los adelantos producidos, 
un programa de ajedrez no sea capaz de ganar siempre a un gran 
maestro? La solución es bien sencilla: el hombre, que no posee m 
la rapidez ni la memoria de una computadora, posee, sin embar¬ 
go, una capacidad que le destaca; el ajedrecista parte de antema¬ 
no'con una heurística, tiene una experiencia, un conjunto de re¬ 
glas, que le permiten eliminar de las miles de jugadas posibles 
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Figura 3.—Una de las últimas aplicaciones de la I.A. son los juegos. 
No se les da más capacidad, sino más conocimiento. 


aquellas cuya posibilidad de ser correctas es más baja, estudian¬ 
do en detalle sólo un conjunto reducido de las jugadas iniciales. 

Este tipo de conocimiento, la experiencia del experto en un 
tema concreto, la posibilidad de incorporar un conocimiento al 
programa es lo que ha llevado al ser humano a investigar en el 
campo de la Inteligencia Artificial, cuyo desarrollo se observa en 
el cuadro de la figura 4 

La LA. trata del diseño de sistemas informáticos inteligentes, 
esto es, sistemas que presentan las características asociadas con 
la inteligencia humana: entendimiento del lenguaje, aprendizaje, 
razonamiento, resolución de problemas, etc. 

Dentro de este concepto han aparecido dos escuelas. Una, lla¬ 
mada de síntesis, que trata de construir sistemas que presenten 
inteligencia independiente de si usan o no internamente los mis¬ 
mo métodos que el hombre, y otra, conocida como de .ilación, 
que intenta emular la forma en la que el ser humano presenta la 
facultad de ser inteligente. 


Periodo 


Sucesos Claves 


Antes segunda guerra 
mundial 

Lógica formal 

Psicología del conocimiento 

La postguerra 1945- 
1954, inicio de la 1. A. 

Desarrollo del ordenador 

Conferencias sobre cibernética 

Los años de formación, 
1955-1960 

Aumenta la disponibilidad de ordenadores 

Lenguaje de proceso de información (IPL-I) 

Psicología del proceso de información 

Los años del 
desarrollo, 1961-1970 

LISP 

Heurística 

Robótica 

Solución de problemas de ajedrez 

DENTRAL (Stanford) 

La especialización 
y los sistemas expertos, 
1970-1980 

MYCIN (Stanford) 

MACSYMA (MIT) 

Ingeniería del conocimiento 

EMYCIN (Stanford) 

PROLOG 

La comercialización, 

1981 

PROSPECTOR (SRI) 

Proyecto japonés de la quinta generación 

INTELLECT (A.I.C.) 

Sistemas inteligentes de recuperación 
de información 

Diversas compañías comercializan herramientas 
para la construcción de sistemas expertos 



llv ■ Figura 4.—Aspectos claves en la historia de la Inteligencia Artificial. 


Retos a los que se enfrenta la Inteligencia Artificial 

De todas las facultades que hacen al ser humano inteligente, 

los investigadores en I.A. están centrando sus estudios en tres 
grandes grupos: 


13 

























• Comunicación y percepción. 

Lenguaje natural. 

Visión. 

Manipulación 

• Razonamiento simbólico. 

• Ingeniería del conocimiento 

1. Comunicación 

Desde el inicio de la década de los cincuenta, cuando por pri¬ 
mera vez se intentó construir un sistema de traducción automáti¬ 
ca mediante la utilización del ordenador, los programas que en¬ 
tienden un lenguaje humano se han convertido en uno de los gran¬ 
des retos de la informática. Pronto se vio la fuerte relación entre 
este campo de la I.A. y la lingüística, lo que está ayudando incluso 
a comprender la naturaleza del lenguaje humano. 

Los japoneses, en concreto en su plan de la quinta genera¬ 
ción de ordenadores, han incluido a la comunicación dentro de 
los temas cuyo avance es necesario para el desarrollo de la cien¬ 
cia; y no sólo los japoneses, sino también los países de la Comu¬ 
nidad Económica Europea y los americanos consideran este cam¬ 
po fundamental como herramienta de progreso. Dentro de estos 
planes se incluyen tres grandes proyectos: 

— Traductor automático multilingüe, con una capacidad de 
100.000 palabras. 

— Sistemas de consulta sobre diversos temas, con más de 
5.000 palabras y 10.000 reglas de inferencia. 

— Sistema capaz de hablar y entender el lenguaje natural, 
con cerca de 10.000 palabras de vocabulario. 

Sin embargo, y a pesar de estos proyectos, han aparecido au¬ 
tores que se oponen a la utilización directa del lenguaje natural 
basándose en que dificultará la comunicación en vez de hacerla 
más sencilla. Han surgido problemas tales como el análisis sintác¬ 
tico y semántico de las oraciones, la ambigüedad de palabras con 
múltiples significados, la determinación del significado de pala¬ 
bras simples donde el contexto general es el que las condicio¬ 
na, etc. El lenguaje humano, aunque bueno para comunicarnos, 
es demasiado ambiguo e inexacto, no muy apropiado para trans¬ 
mitir al ordenador instrucciones precisas sobre lo que debe llevar 
a cabo. 

2. Razonamiento Simbólico. 

En la informática tradicional los ordenadores trabajan con pro¬ 
gramas en los cuales los datos acceden directamente al ordena- 
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M Figura 5.—La comunicación entre el hombre y el ordenador en nues¬ 
tro propio lenguaje es uno de los aspectos clave para los japoneses 
en su proyecto de quinta generación. 


dor, pero las decisiones sobre cómo procesar dichos datos están 
impresas en el lenguaje del programa y almacenadas en la me¬ 
moria durante el proceso de ejecución. Por ejemplo, el programa 
que gestiona las cuentas corrientes'en un banco recibe todas las 
noches unos datos diferentes, pero la forma de procesarlos es in¬ 
variablemente la misma todos los días. 

La Inteligencia Artificial intenta integrar el conocimiento en el 
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.sistema; en otras palabras, un sistema inteligente que escribe su 
propio programa. 

Los sistemas inteligentes se basan en reglas heurísticas, en 

contraste con los programas de cálculo numéricos, basados en el 
uso de ecuaciones analíticas. La heurística hace hincapié, dentro 
del programa, en los aspectos del problema que parecen más crí¬ 
ticos y en las partes de la base de conocimiento que parecen más 
relevantes, y guía al programa en los casos particulares desechan¬ 
do ciertos caminos y centrándose en otros. El resultado es que el 
programa sigue una línea de razonamiento en vez de seguir una 
secuencia de pasos fijos en el cálculo. 

3. Ingeniería del conocimiento. 

Bajo la denominación de ingeniería del conocimiento se agru¬ 
pan todas las áreas que intervienen en el desarrollo de los siste¬ 
mas expertos y bases de conocimientos. Dentro de estas áreas 
aparecen los siguientes campos: 

• Representación del conocimiento Se están desarrollando 
en la actualidad una gran variedad de métodos, todos ellos 
para facilitar el razonamiento simbólico y permitir la codi¬ 
ficación y aplicación del sentido común. Los esquemas más 
habituales de representación son las reglas de producción, 
las estructuras lógicas y el cálculo de predicados. 

• Adquisición del conocimiento. Obtener el conocimiento ne¬ 
cesario para la creación de un sistema experto no es una 
tarea sencilla. En algunos temas el sistema puede aprender 
a través de la experiencia, pero normalmente el experto y 
el programador del sistema deben trabajar unidos para lo¬ 
grar condensar el saber en unas ciertas reglas lógicas. Ac¬ 
tualmente se está trabajando sobre ciertos programas que 
reciben la sabiduría del experto mediante sesiones de en¬ 
señanza. El ordenador va preguntando, analizando las res¬ 
puestas e incorporándolas a la base en forma de reglas ló¬ 
gicas. 

• Métodos de inferencia. Son los métodos que trazan una lí¬ 
nea de razonamiento a una pregunta dada. Estas técnicas 
de generación y análisis de hipótesis son técnicas de con¬ 
centración, al igual que las heurísticas ya mencionadas, es 
decir, centran la atención en determinadas reglas y regis¬ 
tros, marcando la línea de acción. Un problema asociado a 
estos métodos es la cuantiñcación y manejo de datos inde¬ 
terminados, para el cual, aunque a veces se utiliza el teo¬ 
rema de Bayes o el análisis de decisión, se requiere gene¬ 
ralmente el uso de la lógica difusa (Zadeh, 1965). 
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INGENIERIA DEL CONOCIMIENTO TECNICAS DE IA. 








Problema 


Definir el problema 
en términos de estado 
y operadores 


Determinar si el problema 
tiene solución 
algorítmica 


Generar el espacio 
de búsqueda y examinarlo 


Programación tradicional 
(Basic, Fortran. Pascal) 


Identificar el conocimiento 
que se puede aplicar 
para reducir el espacio 
de búsqueda 


Desarrollar un marco 
de conocimiento mezcla 
de inferencia y representación 



M Figura 6.—La definición del problema es uno de los aspectos claves 
en el desarrollo de los sistemas expertos. 


Fronteras de la Inteligencia Artificial 

Aunque es difícil en la actualidad predecir lo que serán ca¬ 
paces de hacer los sistemas inteligentes dentro de sus múltiples 
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Programación convencional 







aplicaciones, sin embargo, a partir del análisis de lo que es posi¬ 
ble y lo que no de los sistemas actuales, se pueden extrapolar al¬ 
gunas ideas a lo que será el futuro de la I.A. en los próximos años. 

Hoy dia, en que la tecnología no ha hecho nada más que co¬ 
menzar, las aplicaciones son muy restringidas; los sistemas basa¬ 
dos en el conocimiento sólo son capaces de enfrentarse y resol¬ 
ver problemas dentro de un campo muy delimitado. No son ca¬ 
paces de razonar a partir de axiomas o teorías generales y sólo 
aceptan un tipo de hechos y heurística determinados. No tienen 
desarrollada la facultad de aprender ni’pueden razonar por ana¬ 
logía. 

La consecuencia de todos estos factores se resume en dos ca¬ 
racterísticas: 

a) La falta de sentido común. 

b) Sus razonamientos se deterioran rápidamente cuando el 
problema se sale fuera de la tarea específica para la que fue di¬ 
señado. 

Por otra parte, los sistemas basados en el conocimiento no 
emiten juicios incoherentes, no se saltan ninguna posibilidad ni 
se empeñan en mantener una postura en contra de los hechos rea¬ 
les. Tampoco tienen malos días, siempre tienen en cuenta todos 
los detalles y sistemáticamente consideran todas las posibles al¬ 
ternativas. Los mejores sistemas expertos, que contienen miles de 
hechos y reglas y sobre todo están diseñados para una función 
apropiada (como, por ejemplo, toda clase de diagnósticos médi¬ 
cos, geológicos, etc.), realizan las mismas funciones que el mejor 
experto y sus juicios y conclusiones son equiparables e incluso 
mejores que la media de especialistas en dicho tema. 
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CONCEPTOS BASICOS 


De la Inteligencia Artificial, 
a los sistemas expertos 

P - ^^7 p uando nació la ciencia de la informática se pen- 

/ i*?» / só que las nuevas máquinas, capaces de reali- 
¡ " ' ¡ zar operaciones aritméticas por sí solas y con 

/ ■ / k una cierta capacidad de operación, iban a re- 

/ 4 solver absolutamente todos los problemas que 

/ ' ; WfU tenía el hombre. 

/ ' Ya entonces se empezó a pensar en orde- 

/ ‘ nadores que hablaran en todos los idiomas de 

[ _ I la tierra, robots "amas de casa", grandes "an¬ 

droides" (mitad hombre, mitad robot) capaces de trabajar en las 
peores circunstancias, etc. Sin embargo, esta euforia inicial, cau¬ 
sada principalmente por el desconocimiento real de la nueva rama 
de la ciencia, acabó muy pronto: Un ordenador tan grande como 
una casa (el ENIAC, por ejemplo) necesitaba "una eternidad de 
tiempo" para realizar una simple multiplicación. 

Posteriormente, cuando pasados unos años de estudios sobre 
el camino que debía tomar esta ciencia en su evolución se resol¬ 
vieron los primeros problemas físicos (como el paso de las vál¬ 
vulas a los transistores y de estos últimos a los circuitos integra¬ 
dos —las famosas "cucarachas"), comenzó de nuevo otra euforia 
sobre la capacidad límite de los nuevos ordenadores. Se podría 
conseguir un ordenador que fuera capaz de almacenar toda la in¬ 
formación que existe en la Biblioteca Nacional de forma que el lec¬ 
tor no tuviera que desplazarse al edificio de la Biblioteca, sino que 
desde su casa podría consultar cualquier libro que estuviera al¬ 
macenado en la memoria del "maravilloso ordenador". Y no sólo 
se pensó en estas tareas: los ordenadores serían capaces de sa- 




M Figura ¡.—En los ya famosos "chips" se encuentra el presente (quizá 
el futuro) de la informática. Su capacidad de operación está crecien¬ 
do día a día. 


berlo todo. Si alguien necesitara saber cuántos goles le metió el 
Athletic de Bilbao al Castellón en el partido de fútbol de Copa en 
1973 y cuántos recibió, bastaría con preguntárselo al ordenador. 

De nuevo el tiempo volvió a demostrar a los desmesurada¬ 
mente optimistas que lo que ellos deseaban todavía iba a tardar 
muchos años en poder realizarse. 

Sin embargo, un "poso" de estas magníficas ideas sí que logró 
cundir en algunos profesionales de la informática. 

Ellos pensaron: "desde luego es muy difícil que un ordenador 
lo sepa todo sobre todo lo que ocurre en el mundo. Sin embargo, 
sí podría ocurrir que un ordenador lo programáramos para que su¬ 
piera todo pero sobre un solo téma". 



M Figura 2.—De los métodos antiguos de manejo de la información a 
los que se utilizan en la actualidad hay una gran diferencia. La co¬ 
municación de ordenadores situados en distintos lugares ha permitido un 
gran avance. 
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Así, pues, podríamos disponer de un ordenador que sólo su¬ 
piera sobre los partidos que se juegan en la Copa del Rey, y nada 
más que sobre eso. Si al ordenador le preguntáramos quién va el 
primero en la Liga, él no lo sabría, puesto que no estudia el tema 
"partidos de Liga”. 

Este tipo de tareas se realizó rápidamente, puesto que lo úni¬ 
co que se necesitaba era memoria suficiente en el ordenador para 
almacenar toda la información (sobre los partidos de Copa juga¬ 
dos, por ejemplo). Pero alguien pensó si no sería posible que el 
ordenador fuera capaz de suministrar información más inteligente 
sobre el tema tratado: Se intentaría que el ordenador diera su opi¬ 
nión sobre quién va a ganar la Copa este año. Para conseguir esto 
hace falta que la máquina trabaje de forma inteligente con los da¬ 
tos que posee (que son los resultados de los partidos de Copa) 
para obtener una información que no poseía previamente. 

Pues bien, al intento de crear un sistema basado en ordena¬ 
dores que se ocupe de un determinado tema y que sea "me dia¬ 
riamente inteligente" se le ha llamado sistema experto sobre ese 

i * 

Lo de "experto" puede referirse a que el ordenador se con¬ 
vierte en un experto sobre el tema tratado debido a la gran can¬ 
tidad de información sobre esa materia que posee. 


Qué es un sistema experto 

Un sistema experto se puede definir, más concretamente, 
como una estructura de programación capaz de almacenar y uti¬ 
lizar. con menos restricciones de las presentes en un programa 
clásico, algún tipo de conocimiento sobre una determinada área. 

Expliquemos un poco esta definición. Como cualquier otro pa¬ 
quete de trabajo sobre un ordenador, el sistema experto es una 
estructura de programación, es decir, es un programa. Sin embar¬ 
go, no es un programa de ordenador normal como el que hace¬ 
mos en el ordenador que tenemos en casa, puesto que su estruc¬ 
tura es diferente: no tiene las mismas partes que tienen los pro¬ 
gramas clásicos. 

Esta estructura de programación es capaz, básicamente, de 
dos cosas: 

• puede almacenar información, como si fuese una base de 
datos, sobre el tema considerado; 

• tiene la facultad de utilizar esa información para obtener 
unos resultados que no existían previamente en el ordena- 

Esto lo realiza mediante una técnica que es la que real- 
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mente diferencia a los sistemas expertos de los programas 
clásicos. 

Otras características específicas de los sistemas expertos se 
encuentran, además de las ya explicadas de uso general (alma¬ 
cenar y utilizar), en la capacidad de aprendizaje y el poder de in¬ 
ferencia. 

La capacidad de aprendizaje de un sistema experto, aunque 
parece una cualidad futurista y extravagante, resulta fácil de im¬ 
plantar; se convierte en una herramienta muy útil a la hora de que 
el sistema mejore respecto del momento de su creación. En cual¬ 
quier caso, la capacidad de aprendizaje es limitada y, además, 
debe estar supeditada al control del ingeniero que gestiona el sis¬ 
tema experto. 

Es importante diferenciar al usuario del "ingeniero del cono¬ 
cimiento". El usuario es la persona que utiliza el sistema, como si 
fuese el dueño de una casa. El ingeniero del conocimiento se ocu¬ 
pa de que el sistema funcione como quiere el usuario (sería el ar¬ 
quitecto, el fontanero, el carpintero, el albañil... todos lo que crean 
la casa y la arreglan para que el dueño se sienta cómodo). 



CAPACIDAD 

DE 

ALMACENAMIENTO 


CAPACIDAD 
DE UTILIZACION 


SISTEMA 

EXPERTO 


CAPACIDAD 
DE APRENDIZAJE 


CAPACIDAD 
DE INFERENCIA 


Figura 3.—Capacidades de los sistemas expertos. 









De momento, y quizá por muchos años, los ordenadores no 
pueden sacar información completamente nueva respecto de la 
pue poseen almacenada. Si a nuestro famoso ordenador, el que al¬ 
macena todos los partidos que se han jugado de la Copa del Rey, 
ie preguntamos quién cree que va a ganar la Copa del año que 
viene, podrá contestar cualquier equipo que ha jugado la compe- 
lición, pero no podrá responder con un equipo que no existe. Esto 
es muy importante. Así, pues, el aprendizaje será, precisamente, 
lo que permita al ordenador realizar las siguientes tareas: 

• completar la información almacenada; 

• utilizar nueva información que necesite para procesos de 
inferencia. 

La nueva información que aprende el sistema puede venir 
por dos caminos diferentes: 

• Del propio usuario. 

En algunos procesos el ordenador puede ser consciente de 
qué nueva información puede cambiar el resultado. El or¬ 
denador "copero" podría preguntar al usuario, antes de dar 
alguna solución: ¿Habrá algún equipo nuevo en Primera Di¬ 
visión el año que viene? Así, en el caso de que exista al¬ 
guno, éste será introducido por el propio usuario y el sis¬ 
tema lo incorporará a sus conocimientos y lo tendrá en 
cuenta como posible solución. 

• De un proceso interno del ordenador. 

En este caso no se consigue información completamente 
nueva, sino resultante de la interrelación de información 
previamente acumulada. t 

Para ofrecer un ejemplo de este segundo método vamos a 
crear otro ordenador que se ocupe de resolver problemas médi¬ 
cos. 

El usuario, en este caso un médico, le introduce al sistema los 
síntomas del paciente y el propio sistema expresa su opinión in¬ 
dicando una enfermedad. Este "médico electrónico" podría apren¬ 
der de la siguiente manera: Supongamos que la información que 
posee el sistema sea 

El frío produce ca t a rros 

Los catarros mal curados producen bronquitis 

Si un paciente dice que hace una semana pasó mucho frío y 
que posteriormente se puso muy malo, el ordenador puede resol- 
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vere que el paciente posee bronquitis. Esta información, que ha 
inducido el propio ordenador, podría aprenderla si creara un nue¬ 
vo hecho de información que fuera: 

El frío produce bronquitis 

Este "médico electrónico" nos sirve además para explicar bre¬ 
vemente la segunda gran cualidad específica de los sistemas ex¬ 
pertos: el poder de inducción. Podemos apreciar cómo a partir de 
una información que ha introducido el-usuario (hace una semana 
que pasó mucho frío) y de unas relaciones entre hechos de infor¬ 
mación que posee, el ordenador consigue una solución, combina¬ 
ción de todo. A la acción de combinar la información para conse¬ 
guir nuevos hechos se le llama inducción. 

Estructura de un sistema experto 

Una vez explicada la teoría de los sistemas expertos y des¬ 
critas las posibilidades y características más importantes, queda 
por definir cómo está formado un sistema experto. Conocer la es¬ 
tructura general de un sistema de este tipo permite clarificar la 
comprensión de su funcionamiento. 

El sistema experto está formado básicamente por dos ele¬ 
mentos: 

• una base de conocimientos, 

• un motor inferencia). 

Analicemos cada uno de ellos: 

• Base de conocimientos. 

En ella se almacena la información referente al tema trata¬ 
do en cada caso por el sistema. La pregunta podría ser: ¿Por 
qué se llama base de conocimientos y no base de datos, si 
al fin y al cabo lo que se almacena en dicha base es infor¬ 
mación? 

Respecto a este tema todavía no se han aclarado los cien¬ 
tíficos. Incluso no se han puesto de acuerdo aún respecto 
a los elementos simples que engloba la propia base de co¬ 
nocimientos. Para profundizar en este problema hay que. co¬ 
nocer los niveles del conocimiento diferenciados en inteli¬ 
gencia artificial, como haremos posteriormente. 

• Motor inferencial. 

Se ocupa de gestionar la base de conocimientos de modo 
que ante preguntas del usuario el sistema ofrezca respues- 
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M .Figura 4 —El esquema general de un sistema experto presenta un 
diagrama de bloques bastante simple. 


tas aceptables. Es decir, se ocupa de tomar las reglas y rea¬ 
lizar inferencias para que tengamos una solución. Más ade¬ 
lante se explicarán estas funciones con más detalle. 

Niveles de conocimiento 

Existen tres niveles de conocimiento que estructuran la infor¬ 
mación que maneja un sistema experto. 

• HECHOS BASICOS DE INFORMACION 

Es el nivel más bajo dentro de la jerarquía de conocimientos. 
Representan simplemente hechos básicos, es decir, ios elementos 

lingüísticos más simples que poseen sentido por ellos mismos. Son 

la base de la información. 

Ejemplos de hechos básicos son: 

"Nuria está como una foca" 

"Nacho tiene gafas" 

“Marcos es diplomático" 

• REGLAS DE CONOCIMIENTO 

Son bloques lingüísticos que representan un determinado tipo 
de información en función de la forma en que se construyan. Es¬ 
tán formados por hechos básicos, aunque puede ocurrir (de he¬ 
cho ocurre en algunos sistemas expertos) que las reglas de do- 
nocimiento pueden por ellas mismas representar la unidad míni¬ 
ma de conocimiento con la que trabaje un determinado sistema 
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experto. Una regla de conocimiento puede representar lo que hay 
que hacer en caso de incendio; y solamente representará eso. En 
el caso de que ocurriera una inundación no podríamos aplicar esta 
regla. 

Para crearla habrá que utilizar como mínimo dos hechos bá¬ 
sicos: el primero representará qué hacer realmente en caso de in¬ 
cendio; el segundo servirá para tener claro que la regla creada 
sólo se debe utilizar cuando hay un incendio y no cuando hay una 
tormenta, por ejemplo. 

Así podríamos crear la siguiente regla: 


Si hay un incpndio ent0nce f corramos lo más rápido que podamos 


i 

hecho 


i 

hecho 


conector 


conector 


Aunque podríamos construir otra regla como: 

Si hay un incendio entonc es intentar apagarlo y pedir ayuda 


i 

hecho 


conector 


conector 


i 

hecho 


i 

hecho 

conector 


donde la propia regla está formada por más de dos hechos. 

Vemos como mediante la información de las reglas de cono¬ 
cimiento se constituye el conocimiento del sistema sobre un tema 
escogido (en el caso anterior, sería cómo tratar un incendio). 

Aunque se explicará posteriormente el significado de los co- 
nectores, vemos ya que su función es unir diferentes hechos para 
crear una estructura (la regla de conocimiento) que posea senti¬ 
do en su conjunto y que además éste debe ser el que pretende¬ 
mos que tenga. 

Se puede ver que la estructura básica de las reglas de cono¬ 
cimiento es: 

Si [hechos-1] entonces [hechos-2] 

donde [hechos-1] es el primer conjunto de hechos, que recibe el 
nombre de antecedente, y [hechos-2] es el segundo, que se le lla¬ 
ma consecuente. 


• REGLAS DE CONTROL 

Representan el último nivel de información en la estructura 
del conocimiento aquí tratada. Una vez constituidas las reglas de 
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conocimiento sobre un tema, se almacenan todas ellas en la me¬ 
moria del ordenador. Sin embargo, ante una pregunta del usuario 
habrá que utilizar, para responderle, sólo unas cuantas de las re¬ 
glas que se poseen, no todas. 

¿Qué reglas deben de utilizarse para contestar al usuario? El 

sistema necesita un instrumento capaz de elegir en cada caso la 
regla que corresponda. 

Siguiendo con el ejemplo del incendio, supongamos que en 
el ordenador tenemos dos reglas de conocimiento: 

Regla A: “Si hay un incendio entonces corre mU y deprisa" 

Regla B: "Si hay una inundación entonces a p re nde rápidamen¬ 
te a nadar" 

En cada caso el ordenador debería analizar las reglas y es¬ 
coger la que realmente tiene que aplicar. Sería muy problemático 
que alguien en un incendio intentara aprender a nadar (aunque 
probablemente no se quemaría). 

La elección de las reglas adecuadas para cada caso se reali¬ 
za en el ordenador por medio de otras reglas, llamadas reglas de 
control. 

Las reglas de control, como su nombre indica, controlan la 
elección de las reglas de conocimiento. Por ejemplo, una regla de 
control podría ser: 

"Cuando ocurra un hecho «A» entonces aplicar todas las reglas 
en que aparezca como antecedente el propio hecho «A». 

Así, en el caso de que ocurriera un incendio se aplicarían to¬ 
das las reglas donde apareciese: 

“Si hay un incendio..." 

La estructura de conocimientos utilizada se engloba én la for¬ 
ma que ilustre la figura 5. 


Asignación de niveles 

Una vez definidos los niveles de conocimiento, el siguiente 
paso es asignarles un lugar en la estructura del Sistema Experto. 

Aquí empiezan las divergencias de opinión entre los cientí¬ 
ficos. 

Para algunos dicha asignación es: 

Hechos básicos forman la base datos rociada al sistema 
Reglas de conocimiento f° rman la base de conocimientos 
Reglas de control f° rman e j motor de inferencia 
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Figura 5.—La estructura que poseen los niveles de conocimientos 
de un sistema experto tiene una forma envolvente. 


Es decir, crean una base de conocimientos formada por reglas y, 
además, el sistema posee una base de datos asociada. 

Para otro grupo de científicos la asignación se realiza de la 
siguiente manera: 


Hechos básicos 
Reglas de conocimiento 


forman la j->- ase conocimientos 


Reglas de control forman el mo tor de inferencia 

En esta asignación la base de conocimientos está formada por 
los hechos básicos y por las reglas de control. 

Para manejar correctamente la inferencia existen gran canti¬ 
dad de herramientas lógicas y matemáticas estudiadas en esfe si¬ 
glo. Entre ellas se encuentran la deducción, la inducción, etc. To¬ 
dos estos métodos matemáticos pueden ser implantados en los 
sistemas para que trabajen con las reglas y produzcan soluciones. 

Una vez estudiadas la estructura y cualidades más importan¬ 
tes de los sistemas expertos podemos realizar un gráfico que aglu- 



M .Figura 6—La asignación de los niveles de conocimiento a cada ele¬ 
mento del sistema experto se puede representar mediante una ca¬ 
nalización de tuberías. 


tiñe perfectamente el trabajo del sistema, tal como el mostrado en 
la figura 7. 

Si nos hacemos la famosa pregunta: ¿por qué a la base de co¬ 
nocimientos no se le llama base de datos? comprenderíamos aho¬ 
ra que en los sistemas expertos la base de conocimientos signi¬ 
fica algo más que información almacenada, puesto que incluye ya 
una cierta "inteligencia" en cómo y cuándo utilizar la información. 
Por eso se llama precisamente Base de Conocimientos. 


Diferencias estructurales con la programación clásica 

Los sistemas expertos representan un paso adelante en la 
ciencia de la programación por su gran diferencia con los progra¬ 
mas clásicos. 

En la programación normal para resolver un problema se crea 
un programa. tEn este programa, que está constituido por líneas 
en BASIC, FORTRAN u otro lenguaje, se encuentran formando una 
unidad tanto la información sobre el método para resolver el pro¬ 
blema como los propios datos particulares del problema. 

Sin embargo, en los programas de inteligencia artificial (y más 
concretamente en los que constituyen los sistemas expertos) se 
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muy importante, puesto que facilita enormemente la evolución del 
sistema al ser modulada su estructura. 

Así pues, el motor de inferencia se construye como un ente 
aislado e independiente de la base de conocimientos. Esto per¬ 
mite crearlo a la vez que otras partes del sistema y así se agiliza 
el proceso necesario. 

Sin embargo, hay que reconocer que no existe un 100% de in¬ 
dependencia entre la base de conocimientos y el motor de infe¬ 
rencia, ya que, como ocurre con todo en esta vida, unos motores 
inferenciales funcionan mejor con un determinado tipo de base 
de conocimiento que con otro y, por tanto, se crean unas peque¬ 
ñas diferencias entre los motores en función de la forma que to¬ 
man el conocimiento sobre el tema. 

Ya tenemos definidas las diferencias de estructura entre los 
programas clásicos y los sistemas expertos. Sin embargo, todavía 
no está muy clara la gran ventaja de estos sistemas. Pueden pen¬ 
sar ustedes que mucho definir y estructurar pero poco diferen¬ 
ciar realmente su funcionamiento; por lo visto hasta ahora se po¬ 
dría haber hecho un programa normal estudiando por un lado la 



BASE DE CONOCIMIENTOS 
OPTIMA PARA EL MOTOR 
DE INFERENCIA “A" 



8.—La base de conocimientos es el elemento diferenciad'or 
múltiples sistemas expertos. No todos se adaptan igual a un 


mismo motor inferencial. 
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mecánica de resolución y almacenando por otro los datos del pro¬ 
grama. Sin embargo, "sí" existen grandes diferencias de funciona¬ 
miento. 


Estructura Sol 

Supongamos que queremos realizar un sistema experto en 
diagnósticos médicos; volvemos a trabajar con nuestro Médico 
Electrónico. El sistema experto que vamos a realizar, como somos 
muy "chulos", podrá resolver cualquier caso sobre cualquier tipo 
de enfermedad (¡imagínense lo que pedimos!); aunque no se ha 
conseguido en realidad, nosotros ya lo tenemos. 

Para enseñar al sistema la primera enfermedad que debe co¬ 
nocer tendríamos que recoger todos los síntomas que conocemos 
sobre ella para luego introducirlos en el ordenador. Tomemos, por 
ejemplo, la gripe: 

• fiebre no muy alta; 

• malestar general; 

• dolores en todo el cuerpo; 

• tos, etc. 

Pero ¿quién nos impide realizar un programa clásico que 
compruebe si tenemos la gripe? Podría tratarse de un programa 
que funcionara de forma que: Si entre los datos de entrada que dé 
el usuario se encuentra algún síntoma que defina la gripe enton¬ 
ces diría simplemente que tenemos la gripe. En caso contrario 
concluiría que no tenemos la gripe. 

Esta estructura (Fig. 9) es la normal en un programa clásico. 
¿Qué ocurre si además de analizar si el paciente sufre la gripe, el 
sistema estudia la posibilidad de que tenga artritis? De nuevo lo 
primero es recopilar los síntomas de la artritis (dolor de articula¬ 
ciones y huesos, pérdida de movilidad etc.); entonces se podría 
crear otro "programa" para reconocer si el paciente posee artritis, 
que se podría juntar con el que teníamos. Así podríamos saber si 
el paciente posee gripe o artritis. 

Pero existe un problema: el programa global debe analizar en 
primer lugar una de las dos enfermedades. Es decir, deberá ver 
primero si el paciente tiene la gripe y luego analizar la posibili¬ 
dad de que sufra artritis (Fig, 10), o al revés. 

Así se podría continuar con todas las enfermedades que co¬ 
nocemos. Esto da la impresión de que cualquier programa reali¬ 
zado de forma clásica podría conseguir los mismos resultados fi¬ 
nales que uno con técnicas de inteligencia artificial. 



ENTRADA DE DATOS: 
SINTOMAS DEL ENFERMO 



BLOQUE DE INFERENCIA CLASICO 
PARA DECIDIR SI EL PACIENTE 
POSEE LA GRIPE 



SALIDA DE HECHOS: 

RESULTADO DEL ANALISIS SOBRE 
GRIPE EN EL PACIENTE 


/ ' i Figura 9— Estructura de un programa clásico. El bloque básico de 
M f inferencia corresponde a un programa simple que realiza una única 
función. 


Sin embargo, la solución final lograda mediante la programa¬ 
ción clásica resultaría muy poco compacta y su funcionamiento se¬ 
ría muy lento al tener que recorrer de una forma predefinida todo 
el espectro de enfermedades que el programa global tuviera al¬ 
macenado. 

Analicemos la forma que va tomando el bloque global de in¬ 
ferencia. Para el caso de la doble posibilidad, anteriormente ana¬ 
lizado, se tiene el bloque de la figura 11. 

En el caso de que se tuviera un programa con más enferme¬ 
dades, es decir con más bloques de inferencia, se conseguiría una 
zona de inferencia como la de la figura 12. 

Los sistemas expertos son mucho más eficaces que los pro¬ 
gramas clásicos porque pueden activar el bloque de inferencia 
que se necesita en cada caso sin necesidad de tener que analizar 
lodos los precedentes. 

Es decir: si el paciente tiene hepatitis, el sistema experto ana¬ 
lizará los datos de entrada que se le han introducido y deducirá 
que tiene hepatitis sin deducir previamente que no tiene gripe y 
que no tiene artritis. En este punto radica la gran ventaja de los 


32 




33 





■ ZONA DE ENTRADA 
I DE DATOS (SINTOMAS) 

▼ 



1.* ZONA INFERENCIA. 
ANALISIS DE GRIPE 


ENTRADA DE DATOS 
SINTOMAS 


POSIBLE 

SALIDA 

ARTRITIS 


2." ZONA DE INFERENCIA 
ANALISIS DE ARTRITIS 


POSIBLE SALIDA DATOS. GRIPE 


M Figura 10— El bloque de inferencia corresponde a un equivalente 
de dos programas clásicos funcionando uno después de otro. Pri¬ 
mero se decide una cosa y luego otra. 


sistemas expertos. De una base de conocimientos formada por mu¬ 
cha información sólo se activa la que corresponde a cada caso en 
función de la entrada de dagos. Esto es lo que se conoce como 
estructura sol (Fig. 13). 

A partir de la estructura sol del sistema experto se puede 
comprender perfectamente el papel fundamental del motor de in¬ 
ferencia. Ante cada problema planteado por el usuario y teniendo 
en cuenta la estructura autónoma del sistema, se pueden activar 
gran cantidad de bloques de inferencia para resolverlo. 

Estos bloques no tienen por qué ser los anteriormente defini¬ 
dos, sino que simplemente son formados por reglas independien¬ 
tes unas de otras, pero encadenadas para resolver el problema es¬ 
pecífico que se plantea en cada caso. 
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Figura 11— La figura representa la zona de inferencia utilizada y su 
representación particular en un programa clásico con dos posibili¬ 
dades. 


La base de conocimientos se presenta como un laberinto (fi¬ 
gura 14). En función de la puerta por la que se entre y en función 
de las normas básicas que utilicemos para atravesarla saldremos 
a un lugar o a otro, obteniendo resultados distintos en cada caso. 

Sin embargo, entre todos los caminos posibles para resolver 
un problema hay uno que resultará el mejor. Para conseguirlo ha¬ 
brá que utilizar las reglas óptimas de la base de conocimientos: 
el motor de inferencia deberá elegirlas. Esta tarea resulta funda¬ 
mental y es precisamente en este punto del problema donde se 
plantean soluciones innovadoras. 

Para elegir las reglas óptimas se pueden aplicar muchos cri¬ 
terios: simplemente mecánicos, es decir, sin que exista ninguna 
"chispa de inteligencia" o bien más heurísticos, basados en la ex¬ 
periencia. La palabra anteriormente citada, heurística, representa 
el eje sobre el que gira la inteligencia artificial y se estudiará con 
más profundidad posteriormente. 

Existe en la actualidad una tendencia a creer que todo pro¬ 
blema informático debe resolverse mediante la creación de un sis- 
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M Figura 12—Según van aumentando las posibilidades en un progra¬ 
ma tradicional, las zonas de inferencia se multiplican. 



tema experto específico y esto es falso. Es cierto que muchos pro¬ 
blemas podrían tener una solución desde el ángulo de la inteli¬ 
gencia artificial, pero ésta puede llegar a ser en ocasiones mucho 
menos eficiente que un programa clásico. Esto es así porque exis¬ 
te un determinado tipo de problemas que pertenecen al entorno 
de la inteligencia artificial y otro que no encaja tan bien. Por tanto, 
antes de realizar un proyecto informático conviene hacer un es¬ 
tudio de viabilidad y elección de las herramientas adecuadas para 
su ejecución. No cuesta demasiado y puede ahorrar mucho tiem¬ 
po y dinero. 


Particularidades de los Sistemas Expertos 

Debido a la gran cantidad de posibilidades a la hora de crear 
el “camino de inferencia" para la resolución de un problema pue¬ 
de ocurrir (y de hecho se espera que ocurra) que ante los pro¬ 
blemas planteados se consigan soluciones no programadas. 
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SALIDA DE 
DATOS - 2 



ENTRADA DE 
DATOS - 2 


M Figura 13.—La evolución de la base de conocimientos vista como 
conjunto de bloques de inferencia da como resultado una estructu¬ 
ra en sol del sistema experto. 


Esto es precisamente lo que se pretende, que el sistema po¬ 
sea "movilidad", que sea algo más que una simple base de datos 
de soluciones. 

Gracias a su estructura el sistema es capaz de explicar, paso 
por paso, su evolución desde las condiciones iniciales hasta la so¬ 
lución final y, además, describir por qué ha tomado cada decisión 
a la hora de las sucesivas opciones dentro del "camino de infe¬ 
rencia". 

Como la base de conocimientos se encuentra separada del 
resto del sistema éste puede renovarse, actualizarse y mejorarse 
en su información sin necesidad de variar su estructura operativa. 
Esto resulta muy importante, puesto que puede utilizarse incluso 
para resolver tareas completamente distintas (dentro de la moda- 
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A, B, C, D, E, F, G, H —» Posibles entradas 
o salidas de la base de conocimiento 

Figura 14.—Una cualidad importante de la base de conocimientos 
es que posee muchas "entradas" y "salidas". En cada caso la salida 
final dependerá de la entrada elegida y de las reglas usadas. En este sen¬ 
tido es comparable a un laberinto. 


lidad de problemas aptos para ser resueltos con la inteligencia ar¬ 
tificial). 


Areas de aplicación de los Sistemas Expertos 

Hemos hablado de problemas que se prestan perfectamente 
a su resolución mediante técnicas de inteligencia artificial, de mo¬ 
tores de inferencia que funcionan mejor con un tipo de bases de- 
conocimiento que con otras y de un largo número de diferencias 
sustancialles. 

Esto nos hace pensar que existirán diversas zonas de aplica¬ 
ción para sistemas expertos en función del tipo de diseño a que 

hayan sido sometidos. 

Cada una de estas zonas es cubierta por un tipo de sistema 


experto que posee las condiciones óptimas para cubrirla. Se con¬ 
sideran dos tipos básicos de sistemas expertos: 

• SISTEMAS EXPERTOS GENERATIVOS 

Como su nombre indica realizan tareas de tipo "creativo'’ (en 

la concepción más limitada de la palabra). Se les intenta introdu¬ 
cir los máximos niveles de inteligencia para que dependan lo me¬ 
nos posible de las directrices fundamentales de cada caso intro¬ 
ducidas por el "hombre". La información que utilizan está com¬ 
puesta por la que le introduce el usuario para cada problema y 
por la almacenada en su propia base de conocimientos. 

Su principal función es el diseño (por ejemplo, industrial, de 
piezas mecánicas, etc.), la inducción de problemas matemá¬ 
ticos, etc. 
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• SISTEMAS EXPERTOS OPERATIVOS O INTERPRETATIVOS 

Su forma de trabajo es menos original que la de los sistemas 
generativos. La información que manejan proviene básicamente 
de la que el ordenador posee almacenada; el peso específico de 
la información que suministra el usuario es menor para valorar la 
actuación del sistema. Son sistemas de tipo consultivo. 

Manejan problemas que no se presentan en los otros siste¬ 
mas, como son el manejo de gran cantidad de información, la co¬ 
rrecta gestión de ésta y problemas de precisión y certeza en la 
información que el sistema presenta como solución al problema 
planteado. 

Los principales campos de operación para este tipo de siste¬ 
mas son el mantenimiento de máquinas, la consulta médica espe 
cializada, etc. 
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Por ejemplo, nuestro sistema "Médico Electrónico" formaría 
parte de este grupo, puesto que lo que realiza es un diagnóstico 
médico del paciente. 



M Figura 16.—El sistema experto interpretativo "interpreta"los datos de 
entrada hasta lograr dar con una solución convincente. 


Ventajas de los sistemas expertos 

La principal ventaja de los sistemas expertos es que, cuando 
realmente sirven para lo que se les construye, optimizan cualquier 
tarea acometida respecto de un programa convencional en un 
tiempo semejante. 

Clasificando estas ventajas se tendría: 

AYUDAR 

El sistema experto puede responder a preguntas que le for¬ 
mulen de una forma directa cuando posee las soluciones almace- 

n. h las i m su memoria. Es decir, puede servir como una ayuda tipo 
agenda. 

Su memoria se utiliza como la del usuario, puesto que los da¬ 
tos que éste pide se encuentran almacenados en el ordenador. 

Por ejemplo, creemos un tercer sistema experto, al que lla¬ 
maremos "Cuida-coches electrónico". Se ocupará de mantener 
nuestro coche en perfecto estado para la conducción mediante la 
información de “cómo se encuentra el coche en cada instante", 
mira los kilómetros, el aceite, el agua, las ruedas, etc., y deduce si 
al coche hay que hacerle alguna reparación, cambiarle alguna pie¬ 
za o funciona bien. Además, como nuestro "cuida-coches electró¬ 
nico" os un sistema experto estupendo, podemos preguntarle cual¬ 
quier cosa sobre el funcionamiento del vehículo. 


Una de las reglas que tendría el sistema sería: 

REGLA I: 

SI EL NIVEL DE ACEITE DEL COCHE ES BAJO entonce s EL MO¬ 
TOR SE GRIPA 

La capacidad de ayuda del sistema experto se pondrá de ma¬ 
nifiesto cuando le preguntemos: 

¿Qué ocurre si el nivel de aceite es bajo? 

puesto que contestará: 

"El motor se gripa" 

No ha hecho ningún tipo de inferencia, puesto que la infor¬ 
mación se encuentra "tal cual" en el ordenador. 

INFERIR 

Representa un paso más evolucionado. El sistema es capaz 
de responder a preguntas con soluciones que no se encuentran 
directamente almacenadas en la memoria del ordenador Esto se 
consigue mediante un proceso de inferencia, de modo que a par¬ 
tir de las premisas iniciales se consiguen hechos que solucionan 
el problema planteado. 

Supongamos que nuestro sistema posee, además de la regla 
anteriormente citada, otra regla que dice: 

REGLA 2: „ ' 

SI EL MOTOR SE GRIPA entonces EL COCHE SE ROMPE 

Un usuario le podría preguntar: 

¿Qué pasaría si el nivel de aceite es muy bajo? 

y el ordenador contestaría: 

"El coche se rompería" 

Podemos ver cómo la información resultante de la utilización 
del sistema ("si el nivel de aceite es muy bajo puede ocurrir que 
el coche se rompa") no se encontraba previamente almacenada 
en el ordenador, sino que ha sido inducida en su funcionamiento 
normal. 

JUSTIFICAR 
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El poder de justificación del sistema se entiende como la fa¬ 
cilidad de exponer todos los pasos del razonamiento realizado por 
el ordenador sobre la base de conocimientos incorporados y la 
modificación de hechos básicos para tener una idea exacta del 
por qué de la solución escogida. 

En nuestro sistema, para continuar con el ejemplo, ante la res¬ 
puesta que nos ha proporcionado el sistema: 

"Ante un nivel de aceite muy bajo ocurriría que el coche se rom¬ 
pería" 

le podríamos pedir que la justificara 

"Si el nivel de aceite es bajo el motor se griparía y si se gripara el 
motor entonces el coche se rompería" 

Con esto la conclusión estaría completamente justificada. 

APRENDER 

Esto es un aspecto poco explicado. La gente que desconoce 
el tema siente un cierto temor (no falto de fundamento "en el fon¬ 
do") ante la posibilidad de que un sistema artificial sea capaz de 
aprender "algo". Sin embargo, la capacidad de aprendizaje de es¬ 
tos sistemas expertos es ciertamente limitada y, además, muy ar¬ 
tificial. 

un aspecto que no se ha comentado todavía de ios sistemas 
expertos es el del aprendizaje inicial que tiene el "programa" an¬ 
tes de que su funcionamiento pueda ser considerado como ópti¬ 
mo. Este aprendizaje inicial, fundamentalmente realizado por el in¬ 
geniero del conocimiento, consiste en enseñar al sistema lo nece¬ 
sario para que éste pueda trabajar con conocimientos sobre el 
tema tratado. En la realidad lo que se hace es llenar la base de 
conocimientos con la información básica sobre el tema. Con esto 
se evitará que el sistema experto se comporte como un verdade¬ 
ro "inútil" antes de haber aprendido lo suficiente. Este primer 
aprendizaje representa, por tanto, la toma de nivel. 

Sin embargo, existe otro aprendizaje que sirve para mejorar 
ese nivel inicial y conseguir que el sistema evolucione, lo que tie¬ 
ne lugar durante la fase de utilización: en él cualquier inferencia 
puede ser almacenada, con lo que se amplía su conocimiento. ■ 

Otra forma de aprendizaje, mucho más artificial todavía, con- 
:;i::te en que cuando el sistema no sabe algo se lo pregunta al 
usuario. 

Siguiendo con el ejemplo de nuestro "cuida-coches electró¬ 
nico", la inferencia que se ha conseguido: 
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"Si el nivel del aceite está muy bajo entonces el coche se rompe" 

podría almacenarse como una nueva regla de la base de conoci¬ 
mientos correspondiente. El sistema habría aprendido. 


Una aplicación de los S.E.: La recuperación de información 

t 

Una aplicación muy importante de los sistemas expertos se 
encuentra en un campo que posee un enorme futuro como foco 
de desarrollo: Se trata de la recuperación de información, campo 
que ha surgido como continuación de los intentos que se realiza¬ 
ron para aglutinar la información de todo tipo en bases de datos. 
Consiste en el estudio de los métodos presentes y futuros cuyo 
fin es optimizar la recogida de información, almacenada en bases 
de datos, con destino al usuario final. 

Actualmente existen muchos problemas, no sólo con la poca 
capacidad de las propias bases, sino con su especificidad, su for¬ 
ma de almacenar la información y la manera de acceder a ella des¬ 
de el exterior. Justamente para intentar mejorar todo esto se está 
aplicando la I.A. 

Los sistemas expertos tienen mucha utilidad en este campo, 
puesto que pueden servir de intermediarios entre las bases de da¬ 
tos y el usuario final. Así, por ejemplo, hoy día es muy difícil con- 
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sultar una base de datos con un lenguaje "natural", es decir, un len¬ 
guaje normal (hablado o escrito), sino que hay que hacerlo me¬ 
diante un lenguaje de comandos más o menos complicado. 

Podría construirse un sistema experto que tuviera como fina¬ 
lidad el poder entender lo que el usuario le pregunte (en su pro¬ 
pio idioma) y luego traducirlo al lenguaje de comandos que la 
base de datos necesita. Con esto se conseguiría facilitar las cosas 
a la hora de que una persona sin conocimientos de informática pu¬ 
diera utilizar el ordenador como si fuera una simple máquina de 
escribir. 

Otra tarea de este sistema experto intermediario podría con¬ 
sistir en llevar a cabo el proceso contrario, es decir, que ante unas 
soluciones (información) enviadas por la base de datos al usuario 



Base de datos 


SISTEMA 

INFORMATICO 


SISTEMA 

INFORMATICO 



PROGRAMAS | 

" ¡: . . 1 

».\v 


-, 


| PROGRAMAS | 




USUARIO 


' Figura 18.—La evolución final de los sistemas expertos de recupe¬ 
ración de información permitirá un manejo óptimo del conocimiento. 
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en forma de comandos se consiguiera que el sistema los transfor¬ 
mara de forma que se pudieran leer como una novela. Con esto 
se evitaría de nuevo el tener que conocer aspectos internos de 
las bases de datos para hacer uso de ellas. 

Ante un futuro que cada vez se ve más próximo, se plantea 
la duda de hacia dónde van a evolucionar los sistemas de recu¬ 
peración de información. Parece claro que las actuales bases de 
datos desaparecerán,, dejando paso a sistemas expertos en los 
cuales la información se almacene en la base de conocimientos. 
Con esto se dará un gran paso, no sólo en la optimización de bús¬ 
queda que se conseguiría, sino porque la información podría ren- 
tabilizarse muchos más. En una base de datos ésta debe de ser 
estructurada mediante procedimientos asociativos, es decir, bien 
mediante relación de unos hechos con otros, bien de forma jerár¬ 
quica, etc. Sin embargo, la base de conocimientos permite alma¬ 
cenar "conocimientos" independientes unos de otros, lo cual re¬ 
presenta una gran ventaja. 

La evolución de los sistemas expertos de recuperación de in¬ 
formación se correspondería con el gráfico de la figura 18. 

Teniendo en cuenta que en la figura está la evolución de los 
sistemas informáticos vista de menor a mayor complejidad y no 
a través del tiempo, podemos observar cómo lo fundamental del 
sistema se encuentra en su capacidad interna de operación me¬ 
diante unos programas. En un siguiente paso, se le "cuelga" al sis¬ 
tema una base de datos para que su trabajo no sea puramente in¬ 
terno, sino que posea conexión con el mundo exterior. Lo siguien¬ 
te que se intenta es, por supuesto, optimizar esa conexión para 
que el sistema le saque el máximo rendimiento. 

Posteriormente, una vez mejorada la comunicación con el 
mundo exterior, se intenta conseguir optimizar la conexión del sis¬ 
tema con el usuario para que éste no tenga que conocer ningún 
tipo de lenguaje especial para comunicarse con el ordenador. 

Por fin el paso del futuro representa el momento en que to¬ 
dos los bloques anteriormente citados se integran en una sola es¬ 
tructura. 
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REPRESENTACION DEL CONOCIMIENTO 



no de los puntos débiles de toda la teoría de 
programación que hemos estado viendo hasta 
ahora estriba en la forma de representar el co¬ 
nocimiento. Hay que buscar una capaz de re¬ 
presentarlo lo suficientemente bien como para 
que resulte efectiva y aprovechable. Parece 
una tontería, pero no lo es; así, supongamos 
que queremos representar la siguiente afirma¬ 
ción: 


"Hoy llueve mucho, pero ayer llovió más de lo que lloverá mañana". 

Desde luego, hasta a una persona le resultaría difícil cuantifi- 
car una información como la anterior, así que si intentamos intro¬ 
ducirla en un ordenador los problemas serán aún mayores. De en¬ 
trada parece imposible que el ordenador sea capaz de saber cuán¬ 
to significa realmente la palabra "mucho”. Lo que nosotros hace¬ 
mos indirectamente cuando nos comentan "hoy llueve mucho" es 
recurrir a una información previa que tenemos almacenada de an¬ 
temano y que adquirimos con la experiencia. Sabemos que cuan¬ 
do llueve mucho el cielo está muy cerrado y el agua que cae em¬ 
papa el cuerpo muy rápidamente. Es decir, tenemos un conoci¬ 
miento aproximado del agua que cae cuando llueve mucho; cuan¬ 
do decimos "llueve mucho" sabemos que cae más de una gota 
cada hora y, desde luego, menos que si nos cayera todo el mar 
Mediterráneo encima de golpe. 

Pues lo mismo debe tener un ordenador para ser capaz de 
manejar este tipo de conceptos. Sin embargo, es muy difícil de 
conseguir, puesto que el hombre lo va aprendiendo desde su na¬ 
cimiento, de tal modo que entra a formar parte de su vida. 
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Por esto todos los métodos actuales de representación del co¬ 
nocimiento son aproximados y no encajan exactamente con lo que 
' 'I hombre desea realmente transmitir. 

Así, para representar la frase anterior podríamos introducir en 
i 'I ordenador algo parecido a los siguiente: 

ll'<y llueve 0.6 pero ayer llovió 0.5 y mañana lloverá 0.3 
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I lomos creado una tabla para la lluvia donde el volumen está com- 
I Hendido en un intervalo (0-1). El 0 significa que no hay un sol es- 
I iléndido y el 1 que está cayendo un aguacero que produce inun¬ 
daciones. 

Hemos generado, pues, una relación numérica entre la infor¬ 
mación que queremos transmitir y su cuantía (Fiq. 1). 

Podemos comprobar cómo al utilizar este tipo de represen¬ 
tación del conocimiento, hemos perdido el significado inicial de 
la frase, cambiándolo por otro aproximado. Si hubiéramos utiliza¬ 
do otra forma de representación, el significado final de la frase re¬ 
presentada habría sido distinto. 

Este problema y otros muchos se plantean a la hora de esco¬ 
ger qué tipo de representación del conocimiento utilizar para 
crear el Sistema Experto. 


Condiciones generales de cualquier tipo de representación 

Antes de definir los distintos tipos de representación que se 
manejan hace falta nombrar las condiciones comunes que deben 
cumplir todos ellos para que sean válidos. 



’ Figura 2.—La ambigüedad es el peor enemigo de la representación 
del conocimiento. 
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Es fundamental eliminar la posibilidad de que en algún caso 
se pueda representar cualquier tipo de ambigüedad, puesto que 
es éste el principal inconveniente para que una representación 
se considere aceptable. 

Parece claro: si queremos una buena representación del co¬ 
nocimiento no puede ocurrir que estemos representando de una 
misma manera varios hechos de información distintos. Hay que 
evitarlo a toda costa. Para ello vamos a analizar los dos tipos bá¬ 
sicos de ambigüedad que existen: 

• AMBIGÜEDAD REFERENCIAL 

Por ejemplo 
"él vino" 

puede tener muchos significados distintos en función del contex¬ 
to en que se encuentre 

— primer significado: 

"Nacho le ordenó a Luis que viniera y él vino" 

En este caso sabemos, por toda la frase, que "él vino" significa 
que Luis vino. 

— segundo significado: 

“Nacho le dijo a Luis: vamos. Sin embargo, Luis se marchó y 
sólo él vino". 

En este caso es Nacho el que viene. Vemos cómo la misma 
frase puede significar cosas distintas en función del contexto en 
el que se encuentre. 

• AMBIGÜEDAD POR EL SENTIDO DE LAS PALABRAS 

Por ejemplo: 

"Marcos cogió una pelota” 

"Marcos cogió un resfriado" 

"Marcos cogió una cogorza" 

Aquí podemos comprobar cómo es la palabra la que crea am¬ 
bigüedad, puesto que el significado de la frase depende de lo que 
“cogió” Marcos. Esta ambigüedad es muy difícil de eliminar y tal 
vez sea, precisamente, la que retrase en muchos años el que los 
ordenadores sean capaces de entender todo lo que el hombre 


pueda contarle en su propio lenguaje, sin ningún tipo de restric¬ 
ciones. 


Tipos de representación del conocimiento 

• REPRESENTACION DE TIPO REDES DE RELACION 

La representación de tipo redes de relación es aquella que 

utiliza estructuras tipo red (malla) para relacionar los conceptos 
entre sí. 

Por ejemplo para representar las frases: 

"Javier es listo" y "Javier es moreno" 
se haría: 


JAVIER 


LISTO 


es 


MORENO 

se puede ver cómo la forma final de representación tiene una es¬ 
tructura tipo red donde los nudos son conceptos y los arcos son 
la relación entre los conceptos. 

• REPRESENTACION DE TIPO LINEAL 

La representación de tipo lineal no utiliza redes de relación, 
sino que su representación es estructural. 

Por ejemplo, para representar las frases anteriores haría algo 
del tipo: 

para "Javier es listo" 

(inst Javier listo) 
y para "Javier es moreno" 

(inst Javier moreno) 

Vemos cómo la representación utilizada tiene una forma li¬ 
neal en su desarrollo (¡¡Ojo, lineal de línea!!). Aunque hay varios 
tipos distintos dentro de la forma lineal, todos ellos tienen en co¬ 
mún que su estructura no es de tipo árbol de relación, de ahí su 
definición. 
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Profundicemos ahora en los dos tipos de representación co¬ 
menzando por el lineal. 


Representación en forma lineal 

La representación en forma lineal utiliza cadenas de palabras 
con una estructura perfectamente definida mediante unas reglas 
de formación determinadas. Cada cadena recibe el nombre de fór¬ 
mula. -• 

Las palabras que forman la fórmula son de dos tipos distintos: 
predicados y argumentos. 

Hay un predicado por cada bloque mínimo de información. El 
predicado enlaza los argumentos para darles sentido en cada fór¬ 
mula. Además, da el sentido que debe tener la fórmula. 

Por ejemplo, la frase: 

"María es alta" 
se representaría, 

(inst. María alta) 

donde "inst” (que proviene del inglés instance) es un predicado 
que enlaza los argumentos María y alta. Su función es definir que 
María es alta, es decir, relacionar "Maria" con "alta". 

La ventaja de esta estructura es que una fórmula ya compues¬ 
ta, como por ejemplo (inst. María alta), puede formar parte de otra 
fórmula más complicada como argumento. Así se consigue una 
..flexibilidad y se permite la construcción de estructuras com¬ 
plicadas a partir de otras más simples. 

En relación con toda esta definición, vamos a analizar un sis- 
lema muy utilizado para trabajar con el ordenador que particula- 
ii/,a las ideas generales que hemos expuesto hasta ahora: es el 
"cálculo de predicados". Posee sus propias normas particulares, 
aunque la base nos resultará conocida. 


Cálculo de predicados 

Ha un método muy utilizado para la representación de propo- 
'lies y para el posterior manejo que de ellas se puede hacer 
pna ic.ilixar inferencias. 

Hásicamente consiste en crear células básicas de información 
(li'n muías), constituida cada una de ellas por predicado y argu- 
.utos. 


El ejemplo anterior sirve a su vez como definitorio del cálcu¬ 
lo de predicados: 

(inst María alta) 

inst -> Predicado 
María -> Argumento 
Alta -* Argumento 

Para evitar la ambigüedad al definir los elementos se asignan 
coeficientes numéricos para conseguir que cada argumento ten¬ 
ga un único significado. 

Por ejemplo: 

(inst Silla-1 Silla) Silla-1 es una silla 

(inst Silla-2 Silla) Silla-2 es una silla 

Silla-1 y Silla-2 son definidas como sillas, pero puede ocurrir 
que una sea clásica y la otra tipo taburete de bar; precisamente 
para diferenciarlas se les asignan coeficientes numéricos distintos. 

• ARGUMENTOS 

Hay tres tipos distintos de argumentos que se pueden utilizar 
en las fórmulas: 

— Símbolos constantes 

— Variables 

— Funciones de aplicación 

Los símbolos constantes pueden ser palabaras que haya que 
relacionar. 

Por ejemplo, 'Juan', 'Hombre’ o cualquier otro. 

Las variables tienen el mismo papel que en matemáticas, es 
decir, pueden tomar cualquier valor dentro del intervalo de defi¬ 
nición que posean. 

Por ejemplo, si tenemos: 

(inst X Hombre) 

lo que se consigue es que la variable "X" pueda tener el valor 
"hombre". 

Las funciones de aplicación son, como ya hemos comentado 
anteriormente, las fórmulas complejas que sirven de argumento 
en otras. 

Por ejemplo, una fórmula compleja que puede utilizarse como 
argumento podría ser: 

(inst Pedro cojo) 


• PREDICADOS 

Como el cálculo de predicados no es un lenguaje en el que 
las palabras "clave" estén definidas previamente, y no hay que uti¬ 
lizarlas forzosamente, se permite una gran riqueza a la hora de la 
representación. 

Esto significa que podemos utilizar como predicados los que 
nos interesen para representar lo que queremos. 

Por ejemplo, podemos tener: 

(hijo-de Marta María) 


— Universal, simbolizado como V (forall) 
se representa de la forma siguiente: 

(forall (X) A) 

y significa que la variable X está cuantificada de forma universal 
en la fórmula A. Por ejemplo: (forall (hombres) han nacido) indica 
que todos los hombres han nacido. 


queremos representar que Marta es hija de María y utilizamos el 
predicado "hijo-de”. 

En realidad el cálculo de predicados sirve de soporte para 
programar en los lenguajes que maneja el ordenador (puesto que 
todavía estamos en el siglo XX). Estos lenguajes, de los que el más 
común en I.A. es el LISP, están estructurados para trabajar con in¬ 
formación alfanumérica, y el cálculo de predicados se amolda mu¬ 
cho a ellos. 

Como subrango del papel que realizan los predicados, tene¬ 
mos los elementos conectores y relacionadores de fórmulas. 

Existen dos básicamente: 

CONECTORES (if, and, or, not) 

tienen la facultad de permitir conocer la certeza o falsedad de la 
fórmula que forman conociendo la del argumento sobre el que ac¬ 
túan. 

Por ejemplo 
(not (inst coche rojo)) 

El significado de esa representación es "el coche no es rojo”. 

Si analizamos el valor podemos ver si el coche que quere- - 
mos representar realmente es rojo, en cuyo caso 
(inst coche rojo) es cierto, 
y sabiendo esto sabemos también que 

(not (inst coche rojo)) es falso, puesto que el coche es realmente 
rojo. 

CU ANTIFIC ADORES 

Hay dos 

Existencial, simbolizado como 3 (exists) 
li< 'ne on el cálculo de predicados un sentido similar al que poseía 
i'ii matemáticas (existe...) 


Reglas del conocimiento 

Cuando estudiamos la jerarquía que existía dentro de los ni¬ 
veles de información comentamos que el conocimiento se conse- 
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M Figura 3—La Figura esquematiza la estructura de toda información 
representada mediante cálculo de predicados. 
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gula precisamente mediante las "reglas del conocimiento". Pues 
bien, estas reglas deben de poder representarse en el cálculo de 
predicados puesto que, en caso contrario, no serviría de nada esta 
teoría. Y, en efecto, se pueden representar. 

Como existen muchas formas de hacerlo nosotros nos hemos 
centrado aquí en las reglas de producción. Su estructura es la tí¬ 
pica de cualquier regla: 

IF (antecedente) THEN (consecuente) 

donde IF y THEN son los conectores ingleses que corresponde¬ 
rían a: 

SI (antecedente) ENTONCES (consecuente) 

Por ejemplo 

" si llueve entonces me mojo" 

La forma de representarla mediante el cálculo de predicados 
tendría el formato siguiente. 

(if P O) 

el significado de esta expresión sería: 'si es cierta la proposición 
P entonces es cierta la proposición Q‘. 

Reglas de control 

Ya hemos visto las reglas de producción. Ahora lo único que 
falta es saber cómo se va a realizar la inferencia y qué se logrará 
inducir a partir de unas reglas del conocimiento iniciales. 

Esto se consigue definiendo para cada sistema las reglas de 
control que lo gobiernan, también conocidas como reglas de in¬ 
ferencia. Trabajan con los hechos básicos y las reglas de produc¬ 
ción para poder deducir, inducir, etc. 

Vamos a analizar algunas de las que existen en las matemá¬ 
ticas lógicas. 

• MODUS PONENS (DEDUCCION) 

La regla de inferencia dice así: dados como información cierta 

(if P O ) 

y 

p 

se consigue tener la certeza de Q. 
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Lo podemos representar como 
(ifPO)l 

->Q 

P 


Por ejemplo: si tenemos como información inicial 


(si llueve entonces me mojo) 
(hoy llueve) 


y 


podemos tener la seguridad de que "hoy me mojo" 

Existe una regla que se puede concluir de la "modus ponens": 
Es la 'modus tollens'. 

Dice así: 


dados: (if P O ) 

y 

0 

se obtiene P. La barra situada sobre la P y la 0 significan NOT 
(NOT P y NOT 0) 


• ABDUCCION 

Es una regla de inferencia muy buena para generar el proce¬ 
so de explicación que se le pide al sistema experto. 

Funciona así: 

Dados * ( if A B ) 

Se saca A. 

Tiene asociado un problema fundamental, y es que puede lle¬ 
var a conclusiones falsas. Por ejemplo de: 

"Nacho tiene dolores” 

y 

"Si enfermas de cáncer entonces tienes dolores” 

se concluye que "Nacho tiene cáncer”, lo cual es como mínimo 
muy aventurado. 

Sin embargo, tiene un gran valor por su avanzado nivel de 
riesgo. 


57 


• INDUCCION 


Por ejemplo: 


Esta regla de inferencia es muy buena en los procesos de 
aprendizaje del sistema experto. Su significado es el mismo que 
posee en las matemáticas clásicas, es decir, se basa en los proce¬ 
sos de generalización matemática a partir de unos ciertos elemen¬ 
tos individuales. Por ejemplo, si tenemos la certeza de: 

"Juan respira” 

y 

"María respira" 

Se puede intentar generalizar que 
"Todos los hombres respiran" 

Es también una regla arriesgada, puesto que fácilmente se incu¬ 
rre en errores importantes al generalizar características que per¬ 
tenecen sólo a elementos aislados. 

Se podría esquematizar de la siguiente forma: 
si definimos 

(P A) 

(cuyo significado sería que 'A' cumple la propiedad 'p'), al tener 
la certeza de (p A) y (p B) podemos inferir: 

(forall (X) (p X)) 

que significa que para todo X se cumple la propiedad ’p‘. Además 
de estas reglas de inferencia existen otras que también se utilizan 
en los sistemas expertos. Con todas ellas se puede conseguir un 
buen motor inferencial; en función de las que se escojan para 
crearlo el motor tendrá unas u otras características. 


Representación tipo redes de relación 


Es la segunda gran tendencia para la representación del co¬ 
nocimiento. 

Se utilizan las estructuras en red como método de relacionar 
conceptos e información. 

La red se compone de nudos y arcos. Los nudos representan 
conceptos y los arcos son los lazos de unión entre ellos: 


A 


B 


Javier_ aprueba _ > estadística 

En estos tipos de representación también hay que evitar la ambi¬ 
güedad. Para ello se utilizan coeficientes numéricos diferenciado- 

res. 

Así: 


Silla-3_es_„ Silla 

color 

Verde 

Silla-4_es_ t Silla 

color 

Rojo 

Podemos observar dos cosas en los ejemplos anteriores: que es 
necesario que existan coeficientes anti-ambigüedad (en este caso 
diferencian dos sillas distintas) y que cada nudo puede ser punto 
de encuentro de varias áreas; con esto se consigue crear una es¬ 
tructura tan compleja como se desee y permite representar con¬ 
ceptos complicados. 

Ahora habría que analizar todo el conjunto de herramientas 
que, actuando sobre este tipo de representación del conocimien¬ 
to, facilitan la creación de alguna estructura que represente las fa¬ 
mosas reglas de producción de la representación lineal. Asimis¬ 
mo también es necesario en este caso controlar los procesos de 
inferencia que tengan lugar en el sistema. 

Para realizar todo este control existen unas técnicas de ges¬ 
tión de grafos y unas propiedades (también de grafos) que per¬ 
miten un manejo muy adecuado de la base de conocimientos. No 
las expondremos aquí en profundidad, sino que nos limitaremos 
a definirlas. 

Algunas de estas herramientas para la gestión de la red son: 

• HERENCIA POR JERARQUIAS 

Las propiedades que posee un concepto las adquieren por 
'herencia' todos los 'hijos' de dicho concepto. 


relación 





Por ejemplo: 


SER HUMANO 


HIGADO 


NACHO-„ MARCOS 

trabaja para 

es novia de es (descripción) 


MOBY 


CALVO 


Todo ser humano tiene hígado. Como Marcos es un ser humano, 
también tiene hígado y no hace falta colgar un arco directamente 
del nudo MARCOS al nudo HIGADO. Lo mismo ocurre con NA 
CHO. 


• DEMONS 

Se utiliza como procedimiento para hallar valores o resulta¬ 
dos partiendo de información ya existente. Supongamos que que¬ 
remos hallar la resistencia eléctrica de un cable de alta tensión. 
Podremos hacerlo si conocemos el tipo de material que forma el 
cable, su resistividad, la longitud del cable y su sección. Si tene¬ 
mos todo eso representado en una red podremos calcular otra 
propiedad del cable como es la resistencia eléctrica. 

Así se tendría: 


CABLE resistividad | p 


longitud 


sección 


L S 


El proceso a seguir debería ser: 

1) Ver si existen sobre el nudo cable las relaciones resistividad, 
sección y longitud. 

2) En caso de que existan, crear una nueva relación donde el va¬ 
lor que le corresponde se consiga mediante la multiplicación 
y división de los valores que posean las anteriores, de la forma 
siguiente: 

Resistencia = Resistividad x Ion gi tud 

sección 
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• DEFAULT 

Se utiliza para permitir, en cierta medida, el trabajo de la red 
con un concepto nuevo: la probabilidad. 

Hasta ahora hemos hablado del almacenamiento y gestión del 
conocimiento sin analizar la posibilidad de que éste no fuera del 
todo cierto o bien fuera inexacto. 

Aunque los problemas de certeza y precisión del conocimien¬ 
to son muy importantes, aquí simplemente haremos referencia a 
ellos y no los trataremos con profundidad. En el caso de que el 
lector pretenda profundizar algo más en este área encontrará una 
bibliografía al final del libro donde encontrará información al res¬ 
pecto. 

El Default (palabra que proviene del inglés y significa "por de¬ 
fecto") se utiliza para facilitar el manejo de información que no po¬ 
see un valor de veracidad absoluto. 



M Figura 4 —Toda información posee dosis de imprecisión e incerti¬ 
dumbre que dificultan, y pueden llegar a hacer imposible, su utili¬ 
zación eficaz. 


61 





Por ejemplo: 

Juan color-pelo (default) | rubio 

quiere decir que el pelo de Juan probablemente sea rubio. 

Existen otros problemas aparte de la probabilidad de verdad 
en una información; ya hemos citado la certeza y la precisión. De¬ 
bido a estos problemas la representación del conocimiento no ha 
podido evolucionar tan rápido como en un principio se preveía. 



ESTUDIO DEL MOTOR DE INFERENCIA 



emos visto ya la problemática básica de la re¬ 
presentación del conocimiento, por qué se ne¬ 
cesita un tipo determinado de representación 
y los múltiples problemas que aparecen al es¬ 
tudiar el tema. Respecto al motor de inferencia 
lo único que hemos comentado es que su prin¬ 
cipal misión era seleccionar las reglas de pro¬ 
ducción que debían utilizarse para resolver 
cada problema propuesto por el usuario y 
cómo el motor de inferencia realizaba sus inducciones mediante 
unas reglas de control determinadas. 

Ahora vamos a analizar un poco más profundamente cómo 
funciona un motor de inferencia "por dentro". , 

Lo primero será estudiar el funcionamiento del motor cuando 
debe actuar, en sus dos fases: evaluación y ejecución. 

Una vez que se profundice en el estudio del motor se expli¬ 
carán los pasos necesarios para que su funcionamiento sea co¬ 
rrecto y ajustado al que se desea, que concretamente, son: la in¬ 
ferencia, el concepto de búsqueda, el control de la operación y 
el control del espacio de búsqueda. 


Fases de operación del motor 

Para resolver un problema mediante un sistema experto hace 
falta recorrer todo un camino de inferencias hasta llegar a una so¬ 
lución final; a lo largo del mismo hace falta que el motor escoja 
muchas reglas de conocimiento que están almacenadas en su 
base de conocimientos. 
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Cada vez que hay que elegir una de esas reglas debe de po¬ 
nerse en funcionamiento toda una compleja estructura que per¬ 
mita escoger la mejor, aplicarla, etc. Esto lo debe hacer el motor 
de inferencia un gran número de veces. 

Para permitir optimizar este proceso el motor está diseñado 
para que funcione por ciclos. Primero realiza una tarea y luego 
otra. 

Las principales fases del motor de inferencia son: 

— Evaluación 

— Ejecución 


• EVALUACION 

Como su nombre indica, en esta fase el motor se ocupa de 
escoger las reglas que debe aplicar para cada problema de entre 
todas las reglas que existen en su base de conocimientos. 

Esto, que parece tan fácil a primera vista, resulta muy com¬ 
plicado, con problemas de difícil solución, como, por ejemplo, los 
conflictos entre reglas, que analizaremos posteriormente. 

La primera etapa de esta fase, como se puede ver en la figu¬ 
ra 1, consiste en la restricción. Se trata de recoger todas las reglas 
que, por su estructura, se puedan aplicar a un determinado pro¬ 
blema planteado. De entre todas las reglas (R) las elegidas forma¬ 
rán un subconjunto R,. 

Posteriormente hay que realizar un filtrado de las reglas se¬ 
leccionadas eligiendo las que encajan perfectamente con el pro¬ 
blema planteado. Se consigue el subconjunto R 2 . 

Una vez que se ha conseguido el conjunto de reglas R 2 hay 
que eliminar de ese subconjunto las reglas que provoquen con¬ 
flictos. Este paso es importante. Supongamos que estamos anali¬ 
zando nuestro coche con el ''maravilloso" "cuida-coches electró¬ 
nico" y supongamos también que en R 2 tenemos dos reglas que 
dicen: 

R, — "Si el coche hace ruido al acelerar entonces hay que parar 
inmediatamente." 

R 2 — "Si el coche hace ruido al acelerar entonces hay que ace¬ 
lerar más todavía." 

Podemos imaginar que el ordenador "se armaría un lío” si tu¬ 
viera estas dos reglas para aplicar al problema propuesto. Por eso 
es necesario resolver todos los conflictos que aparezcan en R 2 . 

Las dos últimas etapas son las que están menos desarrolladas 
actualmente y es aquí en donde flaquean más los sistemas ex¬ 
pertos. 
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RESTRICCION 
R, CR 


EVALUACION 


FILTRO 
R ? CR, 


RESOLUCION DE 
CONFLICTOS ENTRE 
REGLAS R 3 CR 2 


APLICAR R, 
MODIFICACIÓN 
INFORMACION = SOLUCION 


EJECUCION 


M Figura 1.—E1 motor de inferencia funciona mediante ciclos, con unas 
fases perfectamente definidas que van estrechando el conjunto de 
reglas adecuadas para el problema. 


Los bucles de inferencia son lazos cerrados de inducción: su¬ 
pongamos que tenemos 4 reglas A, B, C, D y que al activar "A”, 
ésta nos manda a “B”, "B" a "C", "C a "D" y, por fin "D" a "A". Ten¬ 
dríamos lo señalado en la figura 2. 

Esto obligaría al ordenador a inferir siempre lo mismo, dentro 
de un bucle sin fin. Este problema también debe ser detectado y 
eliminado para que el sistema funcione correctamente. Para evi¬ 
tar los "bucles de inferencia" hace falta una herramienta muy po¬ 
tente. 










M Figura 2.—Los bucles de inferencia son lazos cerrados de inferencia 
en ¡os sistemas expertos. Hay que evitarlos a toda costa. 


• EJECUCION 

Esta fase se ocupa de que las reglas escogidas en la fase an¬ 
terior (suele ser una regla sola) se ejecuten, produciendo un cam¬ 
bio en la información que se presentará como solución del pro 
blema propuesto. 

Una vez realizada la ejecución el sistema comprobará si exis¬ 
te una condición de final y, en caso contrario, pasará a una nueva 
fase de evaluación. 


Funcionamiento del motor de inferencia 

Ya sabemos cuáles son las fases que lleva a cabo el motor. 
Ahora vamos a analizar cómo se hace realmente todo lo que he¬ 
mos explicado anteriormente. 

Existen dos tareas que debe realizar el motor. 

• Inferencia 

Se debe de aplicar la inferencia al ejecutar una de las re¬ 
glas. Estas se ejecutan en función del tipo de inferencia que 
posea el sistema experto. 

• Control 

El control se ocupa de toda la gestión del sistema que-he¬ 
mos analizado anteriormente; tanto de la forma en que se 
escogen las reglas como de la resolución de conflictos o 
de la eliminación de bucles de inferencia. 

Iimportante el papel que juega el usuario en esta fase en la ma¬ 
yoría do los sistemas, pues muchas veces el ordenador no cono- 
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ce algunos datos importantes para gestionar el sistema y enton¬ 
ces se los pedirá al usuario. De esta forma se puede suplir la falta 
de información. 

Dentro de la fase del control hay que distinguir dos tipos: 

— Control del espacio de búsqueda 
Se ocupa de gestionar "cómo se escogen las reglas” en función 
del espacio de búsqueda concreto (conjunto de reglas que se 
pueden aplicar dependiendo de cada problema). 

— Control de la operación 

Se ocupa de resolver conflictos y realizar todas las tareas para ges¬ 
tionar la fase de evaluación. 

• INFERENCIA 

Para realizar las inferencias hay que tener almacenadas unas 
determinadas reglas de control que enseñen al sistema cómo lle¬ 
varlas a cabo. 

Las reglas de control (llamadas también reglas de inferencia) 
las hemos estudiado ya y no las repetiremos; corresponden al Mo- 
dus Ponens, Abducción, etc. 

Aquí se puede comprobar dónde se aplican las reglas que se 
analizaron anteriormente. 

• CONTROL 

Ya hemos definido varias veces las tareas de control de un 
sistema experto para que funcione bien. Este debe de enfrentarse 
con dos problemas básicos, consistentes en disponer de métodos 
para: 

• decidir dónde empezar a analizar las reglas que se alma¬ 
cenan en la base de conocimientos; 

• resolver los conflictos entre reglas y los bucles de induc¬ 
ción. 

Además de resolver estos problemas, es necesario que el sis¬ 
tema trabaje óptimamente gestionando el espacio de búsqueda 
de una forma adecuada. 


ESPACIO Y ARBOL DE BUSQUEDA 

Cuando en etapas anteriores definíamos el motor de inferen¬ 
cia como el elemento del sistema que debía escoger las reglas 
que se tenían que aplicar en cada momento, no se comentó nada 
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de cómo se conseguía esta elección; el proceso es realmente com¬ 
plicado. 

Como sabemos, el ordenador no puede inventar nada. Todo 
lo que haga debe haber sido programado previamente. 

Por tanto, los métodos de elección de reglas no son "inteli¬ 
gentes" tal y como nosotros lo entendemos. 

Para evitar el problema que esto representa se ha creado toda 
una teoría de modelización que intenta esquematizar al máximo 
todo el problema. 

Así se crea inicialmente el concepto de 
Cuando debido a la aparición de un problema se activa la pri¬ 
mera regla para resolverlo, ésta podrá permitir la aplicación de 
un determinado número extra de reglas y cada una de ellas per¬ 
mitirá la aplicación de otras. 

Así se crea un árbol (grafo 1), que representa el conjunto de 

El problema quedará resuelto 
cuando a lo largo de todo el árbol (árbol de búsqueda) se consi¬ 
ga encontrar un camino que nos lleve a la solución. 



M Grafo 1.—Arbol de búsqueda genérico, con las reglas y subreglas 
situadas en los distintos modos. 


En función de la regla elegida inicialmente se tiene un árbol 
diferente. El árbol completo para un problema determinado nor¬ 
malmente suele resultar extenso. 


Gestión de los árboles de búsqueda 

Cuando ya se posee el árbol de búsqueda para la resolución 
del problema aparecen muchas formas de gestionarlo. Para elegir 
entre ellas se suelen realizar estudios sobre la forma que posee 
dicho árbol, distinguiéndose dos tipos básicos en función de los 
problemas que hay que resolver. 

Supongamos que el problema a resolver es que queremos ir 
al teatro. Para ir al teatro hay muchas formas posibles: en coche, 
andando, en autobús, etc. 

Lo que debemos hacer es escoger entre las múltiples formas 
la que más nos convenga en función de la distancia, el clima, el 
precio, etc. 

El árbol de búsqueda que tendremos será del tipo mostrado 
en el grafo 2. 



M Grafo 2.—Posible árbol de búsqueda para "ir al teatro", pertenecien¬ 
te al grupo de ¡os que van reduciendo posibilidades al avanzar en 

ellos. 


Existen otros problemas, sin embargo, en los cuales el árbol 
de búsqueda es completamente distinto. Por ejemplo, cuando que¬ 
remos predecir algo pero no sabemos concretar, puesto que de¬ 
pende de los datos iniciales que se posean. 


Se trata de inferir posibles consecuencias de los hechos. El ár¬ 
bol de búsqueda sería algo parecido al del grafo 3. y 


QUEMADURAS DESHIDRATACION 



Grafo 3— En algunos árboles lo que se produce es una mayor "ra¬ 
mificación" según profundizamos. 


Estos dos árboles dan pie a distintas maneras de gestionarlos. 

Cuando como en el primer árbol, se parte del objetivo a cum¬ 
plir y se busca la manera de realizarlo, al método se le llama en¬ 
cadenamiento desde atrás. Parte del final para llegar al principio. 

Sin embargo, si, como en el segundo método, se parte del co¬ 
mienzo y se deja evolucionar el sistema hasta que llega al obje¬ 
tivo, se llama encadenamiento desde delante. 

En función del tipo de problema que se vaya a resolver ha¬ 
brá que utilizar una de estas dos teorías para gestionar la elec¬ 
ción de reglas correspondiente. 

Esto significa que estos dos métodos son formas de plantear 
el problema y no políticas de elección de reglas. 


Un camino en el árbol: elección de reglas 

Una vez escogida la manera de gestionar el problema se plan¬ 
teará la política de elección de reglas que se desea. La elección 
de reglas representa encontrar un camino sobre el árbol de bús¬ 
queda. Y, claro está, hay muchas formas de conseguir un camino 
(escoger reglas), cada una de ellas diferentes. 

Se diferencian generalmente dos formas de realizar la elec¬ 
ción. 

• Escoger las reglas de una manera mecánica 

Se crea una función predefinida que escoge las reglas siem¬ 
pre desde un mismo punto de vista. 


• Escoger las reglas de forma más inteligente 

Generalmente se utilizan métodos de evaluación del estado 
en que se encuentra el sistema de forma que en función de la elec¬ 
ción de una regla determinada se alcance más rápidamente la so¬ 
lución. Muchas veces se aplica la experiencia acumulada de otros 
procesos. Son los llamados métodos heurísticos. 

ELECCION MECANICA 

Para conseguir un camino de forma mecánica en el árbol de 
búsqueda que representa al problema planteado existen dos for¬ 
mas básicas. 

t 

BUSQUEDA EN PROFUNDIDAD 

Como su nombre indica, se trata de partir del nudo inicial y 
buscar la solución al problema profundizando lo máximo posible 
en el árbol de búsqueda. Cuando se llega a un punto donde no 
se puede continuar entonces se retrocede para buscar un nuevo 
camino en profundidad. 

Veamos un ejemplo aclaratorio. Supongamos que, viendo el 
árbol del grafo 4 hemos resuelto el camino para conseguir la so¬ 
lución. 

De la figura se deduce que si aplicamos las reglas A, B, E e I 
(en ese orden) llegamos a solucionar el problema. 

Una búsqueda en profundidad buscaría la solución rastrean¬ 
do el árbol de la siguiente forma, (ver grafo 5): empezaría por A, 
continuaría escogiendo un nudo descendiente del A, podría ser 
el B o el C. Toma el B de una forma arbitraria. 

Una vez escogido el B se analiza si se ha llegado a la solu- 



A 



I 


SOLUCION 


Grafo 4.—Camino válido para alcanzarla solución (y óptimo). 


ción, que se encuentra en el nudo I. Como no se ha llegado se pro¬ 
fundiza hasta D. Al llegar a D, que tampoco es solución, no se pue¬ 
de continuar; por lo tanto se vuelve a B para pasar posteriormen¬ 
te a E. Después a H y una nueva vuelta a E para por fin llegar a 
la solución. 

Este es el método de búsqueda en profundidad. 

BÚSQUEDA EN EXTENSION 

Va recorriendo todos los nudos de cada nivel. Ante el mismo 
problema, planteado en el mismo árbol de inferencia, una búsque¬ 
da en extensión actuaría de la siguiente forma (representada en 
el grafo 6) 

Se partiría inicialmente del nudo A; como en el caso anterior, 
se pasaría al nudo B. Una vez analizado que no se ha llegado a la 
solución, en vez de continuar en profundidad se continua "en ex¬ 
tensión", analizando el nudo C. De C, como no existe otro nudo "al 
mismo nivel" se pasa al nudo G. Así se van analizando todos los 




nudos del mismo nivel hasta D. Se baja hasta H y de H se pasa 
a I, la solución final. 

El escoger uno de estos dos métodos depende, como en el 
caso de las estrategias de búsqueda, del tipo de problema que se 
pretenda solucionar. 

Lo que ocurre normalmente es que los sistemas expertos se 
diseñan sólo con un tipo de método, por lo cual adquieren pecu¬ 
liaridades que les hacen específicos para un tipo de problemas 
determinado. 

ELECCION HEURISTICA 

Al fijar una forma mecánica de escoger las reglas (por ejem¬ 
plo, en profundidad) se puede comprender que el sistema no po¬ 
see ningún tipo de conocimiento sobre si durante su operación 
se está acercando a la solución o bien se está alejando. 

Simplemente toma una regla y comprueba si ha llegado al fin 
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SOLUCION 


BBBBI Grafo 6—Sistema de búsqueda mecánica por extensión. 


que se pretende; en caso negativo escoge una nueva regla en fun¬ 
ción de la norma que tiene fijada. 

Lo que pretenden los métodos heurísticos de elección de re¬ 
glas es precisamente dar información al sistema acerca de cómo 
se encuentra en cada instante y, lo que es más difícil, sobre cómo 
quedaría aplicando una determinada regla. Una vez que se posee 
esa información, el sistema puede escoger la regla que optimice 
su operación. 

Por ejemplo, si se consiguiera saber exactamente cómo se 
comporta el sistema ante el problema que propusimos anterior¬ 
mente, la elección de reglas sería precisamente la que diera el ca¬ 
mino directo desde el estado inicial hasta la solución, es decir, se 
aplicarían las reglas A, B, E, I por ese orden. Podemos comprobar 
cómo este método utiliza el mínimo número de reglas. Es el más 
rápido y preciso. 

Como realmente no existe un método capaz de conocer 
perfectamente el problema, se utilizan aproximaciones que lo 


que permiten es reducir al mínimo los errores en la elección de 
reglas. 

Estas aproximaciones son funciones o algoritmos que coloca 
el ingeniero del conocimiento y que él debe escoger. En este ca¬ 
mino se encuentran los últimos adelantos en inteligencia artificial 
que se realizan en Estados Unidos, Japón y Europa. 
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PROCESADORES DE LENGUAJE NATURAL 


as necesidades de información y manejo infor¬ 
mático a los que están sometidos la mayoría de 
los profesionales en los más diversos campos 
está provocando un cambio sustancial en la re¬ 
lación hombre-ordenador. No es el especialista 
en informática el que tiene que contactar con la 
máquina, sino estudiosos de otros temas, normal¬ 
mente usuarios inexpertos en su manejo. 

La inteligencia artificial ha permitido dise¬ 
ñar una serie de herramientas, los procesadores del lenguaje na¬ 
tural, que faciliten la interrelación hombre-ordenador y permitan 
una comunicación mucho más fluida y menos estructurada que 
los sistemas tradicionales de menús. 

Los procesadores de lenguaje natural están compuestos fun¬ 
cionalmente de un analizador, un diccionario y un direccionador. 
El analizador estudia, bien sintáctica o semánticamente, la estruc¬ 
tura de las oraciones con ayuda de reglas incorporadas al siste¬ 
ma. El diccionario expresa relaciones entre conceptos y almace¬ 
na palabras, siendo el direccionador el encargado de pasar del 
lenguaje natural analizado a un lenguaje formalizado, propio del 
sistema donde se está trabajando. 



Necesidad del lenguaje natural en la comunicación 
con el ordenador 

Desde el momento en que el ordenador ha empezado a in¬ 
troducirse en la industria, los servicios públicos e incluso en nues¬ 
tros hogares, surge la necesidad de facilitar al usuario la comuni- 







cación con el mismo. Desde el inicio de la era del ordenador una 
de las grandes tendencias ha sido la de facilitar el trabajo con las 
máquinas, siendo éstas las que lleven el mayor peso posible en 
dicha interrelación. Es hora de que se desarrollen paquetes de 
software que permitan al usuario consultar por sí mismo, sin mu¬ 
chos conocimientos previos y en su lenguaje natural, y que sea 
el ordenador el que realice la tarea de traducirlo al lenguaje for¬ 
mal de la propia máquina. 

Si bien el campo del lenguaje natural tiene una accidentada 
y triste historia, la inteligencia artificial y las herramientas que uti¬ 
liza pueden ser la tecnología que hacía falta para un funcionamien¬ 
to satisfactorio de los interfaces. Es necesario resaltar desde el 
principio que los procesadores de lenguaje natural (PLN) son to¬ 
davía muy limitados en sus aplicaciones para no dejarse inundar 
por un excesivo optimismo. Los problemas inherentes a la natu¬ 
raleza del lenguaje, tales como su escasa lógica o sus múltiples es¬ 
tructuras, no están ni mucho menos resueltos y existen muchos de¬ 
tractores de su utilización. 

La aplicación más inmediata de los procesadores de lengua¬ 
je natural es la recuperación de información. A la vez que se 
desarrollan sofisticados métodos de manejo de información, tales 
como los sistemas inteligentes de recogida, catalogación y recu¬ 
peración automática, se vio la necesidad de mejorar también el 
interface con dichas bases de datos. Si se consigue enseñar al or¬ 
denador lo suficiente del lenguaje natural como para que sea ca¬ 
paz de entender las preguntas planteadas, se eliminan dos gran¬ 
des inconvenientes: 

• El intermediario humano. Es difícil que el intermediario 
comprenda realmente lo que el usuario quiere preguntar 
debido, fundamentalmente, al distinto conocimiento del 
tema que poseen ambas personas; 

• Tener que enseñar al usuario, profesional en otros campos, 
los lenguajes propios del ordenador. 


Funciones que realiza un procesador de lenguaje natural 

Los procesadores de lenguaje natural son capaces de reali¬ 
zar una variada serie de funciones: 

• Permiten al usuario tener un menor conocimiento del sis¬ 
tema, debido a que evita la utilización de estructuras fijas. 

• Corrigen errores de tipo léxico. Al reconocer una palabra 
que contiene una falta, el programa intentará asociarla con 
alguna del diccionario. Si alguna de éstas encaja lo suficien¬ 


te confirma la corrección del fallo y la frase es analizada. La¬ 
deen sistema experto sobre información naval, nos propor¬ 
ciona un ejemplo: 

* ¿Cuánto dista Kitty HwK de Gibraltar? 

Corrección Hawk 

Analizado. 

• Permitir al usuario construir sus frases de manera incremen- 
tal, refiriéndose a frases anteriores. Esta capacidad se de¬ 
nomina anáfora y existen dos tipos: 

* Sustitución y elipsis. El PLN puede sustituir el signi¬ 
ficado de alguna palabra previa (sustitución) o bien enten¬ 
der una pregunta en la que no aparece ninguna referencia 
previa (elipsis). 

* ¿Qué coches corren a más de 100 Km/h.? 

* ¿Cuáles de ellos entre 100 y 150 Km/h.? (sustitución) 

* ¿Cuáles entre 150 y 200 Km/h.? (elipsis) 

* Referencias a pronombres. Un pronombre, a diferen¬ 
cia de una sustitución, se suele aplicar a valores anteriores 
más que a significados. 

* ¿Por qué cortaste la madera? 

Para hacer una cama 

* ¿Cómo lo hiciste? 

• Responder a preguntas de forma inteligente. 

A la pregunta: 

¿Está Begoña matriculada en octavo curso? 

(Y el octavo curso no existe), la respuesta puede ser: 

* No 

* No, no existe el octavo curso (mucho más clara y pre¬ 
cisa). 

• Permitir la ampliación de las reglas gramaticales. Es de mu¬ 
cha utilidad que ios PLN se puedan ampliar fácilmente, pues 
así permiten su sencilla adaptación a todo tipo de usos par¬ 
ticulares. 


Problemas que presentan los PLN 

Del conjunto de problemas que afectan a los procesadores 
de lenguaje natural vamos a citar los más importantes. Un conjun¬ 
to de problemas surge de la gramática del lenguaje. Lo ideal se¬ 
ría un procesador que tuviera toda la gramática incluida, pero es 





obvio que, por el momento, esto excede la capacidad de los or¬ 
denadores, al existir un número muy importante de reglas en una 
sintaxis completa. La solución apunta hacia dos vías: desarrollar 
sólo un subconjunto de la lengua aplicando unas cuantas reglas 
sintácticas, o bien obviar la falta de una gramática completa cons¬ 
truyendo un sistema que tenga en cuenta ente conside¬ 

raciones de iipo semántico. 

Una dificultad tan importante como la anterior son las pregun¬ 
tas gramaticalmente mal construidas. Ciertos investigadores se in¬ 
clinan por construir procesadores que se anticipen al error inclu¬ 
yéndolo en las reglas sintácticas, mientras que otros, haciendo me¬ 
nos hincapié en consideraciones sintácticas, logran sistemas me¬ 
nos sensibles a dichos errores. 

Otro problema a considerar, por su amplia utilización, es el 
uso de pronombres. Al aparecer uno, el analizador debe resolver¬ 
lo antes de poder enviar la pregunta al sistema. Veamos con un 
ejemplo la importancia de éste factor. 

* ¿Tienen todas las chicas moto? 

Si 

* ¿Cuántas tienen más de 16 años? 

El usuario tiene en mente que la edad de conducir una moto 
ronda los 16 años, por lo cual la segunda pregunta alude a las chi¬ 
cas. El ordenador, por su parte, puede no ser partícipe de dicho 
conocimiento y no saber cuál de los nombres —Chica, —Moto 
concuerda con la pregunta. 

Estos y otros problemas dan una idea de la complejidad de 
los procesadores de lenguaje natural y del largo camino de in¬ 
vestigación que queda por recorrer. Si se piensa que la solución 
pasa porque el usuario hable mejor se desvirtúa el propósito de 
estos interfaces, que es permitir al profano comunicarse en su pro¬ 
pio idioma. Todo intento de poner restricciones es desvirtuar su 
finalidad. 

Como resumen podemos decir que !o.s procesadores de len¬ 
guaje natural no llegarán al mercado hasta dentro de unos años 
debido fundamentalmente a tres factores: 

• Se requieren grandes ordenadores para su implantación. 
No sólo para contener al PLN, sino también el sistema al 
que va asociado debe ser de cierta importancia y capaci¬ 
dad. 

• Tipificar todo el lenguaje es una ardua tarea, por lo que, de 
momento, se utilizarán lenguajes parciales. 

• El lenguaje humano es poco apto para transmitir informa¬ 
ción clara, concisa y precisa. 
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Arquitectura de un procesador de lenguaje natural 

Un procesador de lenguaje natural es uno de los módulos que 
componen un sistema de recuperación de información. Su misión 
es analizar, tanto semántica como sintácticamente, las preguntas 
del usuario y crear una estructura formal que luego se traduzca 
al lenguaje propio del sistema asociado. 

El proceso que sigue una pregunta se puede resumir median¬ 
te un diagrama de bloques (Fig. 1); el procesador de lenguaje na¬ 
tural abarca únicamente los tres primeros módulos. 


PROCESADOR DE LENGUAJE NATURAL 



Pr egunta ) Análisis I . I Análisis fe _ 1 Direc- || - Í"I " ~ 1 

| sintáctico | j semántico | | donador I H Traducción I Slste ^ a 

asociado 

M Figura 1.—Flujo de trabajo de un procesador de lenguaje natural. 

Partiendo de una pregunta se crea una estructura única comprensi¬ 
ble por el sistema asociado. 


Casi todos los productos que hoy en día se comercializan en 
el mercado presentan esta distribución. El intérprete francés SAP- 
HIR, como se puede apreciar en la figura 2, tiene una gran simili¬ 
tud con el esquema típico de estos sistemas. En él se pueden apre¬ 
ciar los módulos de corrección de errores morfológicos y léxicos, 
así como el que realiza la función de concretar, estableciendo un 
diálogo con el usuario, las preguntas ambiguas o imprecisas. 

Üna vez visto de forma general dónde se enclava un PLN, el 
siguiente paso es describir en mayor detalle los distintos módu¬ 
los que componen dicho sistema (Analizador, Diccionario y Direc- 
cionador) y su implantación en diversos programas. 

EL ANALIZADOR 

El analizador es el programa que estudia la gramática de la 
oración. Dicha gramática definirá la función de cada palabra den¬ 
tro de la frase. La clave del éxito o del fracaso de un procesador 
de lenguaje natural es la representación de dicho lenguaje. 

Entre los distintos tipos de representaciones las más común¬ 
mente usadas son los árboles funcionales y las estructuras temá¬ 
ticas, apoyándose ambas en la forma en que una idea se expresa 
en palabras y frases. En la primera el analizador (o parser) crea 
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SAPHIR 


USUARIO 



f Figura 2—Arquitectura real de un PLN, el SAPHIR, desarrollado en 
Francia como interface para una base de datos inteligente. 


los árboles a partir de las reglas sintácticas de construcción de 
oraciones, mientras que el procesador de estructuras determina 
cómo los distintos sintagmas nominales se relacionan con el verbo. 

Si se considera la frase "Begoña compró unas manzanas rojas 
en el mercado”, el árbol funcional se compondría (tal y como se 
aprecia en la figura 3) de un sintagma nominal, más el sintagma 
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M Figura 3.—Arbol funcional resultado de un análisis sintáctico me¬ 
diante una gramática de libre contexto. 
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BEGOÑA COMPRO UNAS J*™' ROJAS EN EL MERCAD! 

































verbal, compuesto a su vez del verbo con su sintagma nominal, y 
la frase preposicional con su sintagma nominal correspondiente. 

Por otra parte, el procesador de estructuras temáticas indica¬ 
ría que el acto es "comprar”, el agente "Begoña”, el objeto temá¬ 
tico "manzanas rojas" y el lugar o procedencia “en el mercado" 
(Fig. 4). 

Como vemos, los métodos son completamente diferentes: en 
los árboles el fin del analizador es determinar la función de cada 
palabra dentro de la oración, mientras que en las estructuras te¬ 
máticas es determinar cómo se relaciona cada sintagma nominal 
con el verbo. Son dos teorías que en algunos casos se pueden 
complementar, la sintaxis y la semántica. 

Dentro de los árboles funcionales se han definido cuatro mé¬ 
todos de construcción de los mismos: la gramática de libre con¬ 
texto, las redes de transición, las redes de transición aumentadas 
(ATN) y el analizador WASP (Wait-and-see), siendo cada uno de 
ellos más complejo que el anterior. 

Por el contrario, en las estructuras temáticas sólo existe un mé¬ 
todo: averiguar el papel que los sintagmas nominales juegan den¬ 
tro de la oración Uno de ellos se identificará con el sujeto que rea- 


ACTO 



Figura 4—Estructura temática de la oración “Begoña compró unas 
manzanas rojas en el mercado''. El análisis es semántico. 


liza la acción, otro con lo que se realiza (objeto directo) y otros 
con diversas circunstancias. El número de papeles temáticos va¬ 
ría según el tema o la persona que construya el sistema pero se 
pueden destacar las siguientes: 


— Sujeto o Agente 

— Objeto temático 

— Instrumento 

— Lugar 

— Beneficiario 

— Destino 


Begoña se comió un pastel. 

Nacho rompió la radio. 

Nacho rompió la radio con un martillo. 
Carlos estudia en casa 
Alicia tomó un plátano para Antonio. 
Los alumnos se fueron a Madrid. 


EL DICCIONARIO 


La función fundamental de un diccionario, aparte de almace¬ 
nar un conjunto de palabras, es representar las relaciones entre 
las misma:; Una palabra puede representar una relación, un atri¬ 
buto o un valor Igual que el analizador debe contener categorías 
gramaticales y, por otra parte, un gran número de significados. 

El diccionario puede estar estructurado en forma de redes, 
donde cada nudo es una palabra y el arco entre dos nudos la re¬ 
lación entre los mismos, o bien en forma de campos jerárquicos. 

Una característica que debe incorporar el diccionario es la po¬ 
sibilidad de aceptar nuevas palabras que el usuario va introdu¬ 
ciendo en la conversación; por ejemplo: 

(usuario) — El profesor da clases de LATIN. 

(ordenador) * No entiendo la palabra LATIN 

1) Es un sitio. 

2) Es un idioma. 


La próxima vez el diccionario identificará la palabra latín co¬ 
rrectamente. 


EL DIRECCIONADOR 

La representación interna de las preguntas en lenguaje natu¬ 
ral es uno de los aspectos claves en un procesador. De todas las 
posibles representaciones se debe optar por la que más fácilmen¬ 
te se ajuste al idioma utilizado. No deben existir, al contrario que 
en el lenguaje natural, inexactitudes de ningún tipo: todos los pre¬ 
dicados en la representación interna deben ser precisos. Una am¬ 
bigüedad puede producir errores posteriores. Asimismo, la estruc¬ 
tura funcional (es decir, cómo están ordenados funcionalmente los 
distintos objetos) debe quedar explicitada en el predicado. 


84 


85 










Procesadores de alto nivel 


Los procesadores de alto nivel conectan con sistemas de re¬ 
cuperación de información no tradicionales; su campo de acción 
son los sistemas expertos, con los que forman un conjunto de pres¬ 
taciones muy apreciables. Para dar una idea de la capacidad de 
estos procesadores veamos cómo es capaz de generalizar ideas 
y catalogar conceptos un sistema denominado "Nano Klaus": 

Un submarino es un barco. 

* ¿Está diciendo que todo submarino es un barco? 

* O K. Ahora he asimilado lo que es un submarino. 

Un destructor es un barco. 

* Está diciendo que todo destructor es un barco. 

* ¿Es el submarino una clase de destructor? 

* ¿Está el submarino compuesto de diferentes elementos 

que el destructor? 

* ¿Componen el submarino y el destructor todos los bar- 




A partir de esta conversación el sistema clasificará a los sub¬ 
marinos y a los destructores correctamente dentro del sistema. 

Los sistemas de alto nivel no están en la actualidad comercia¬ 
lizados y sólo existen unos pocos prototipos en experimentación. 



LENGUAJES DE PROGRAMACION 
Y HERRAMIENTAS DE I.A. 


na vez que se han estudiado los métodos de 
representación del conocimiento y las técnicas 
de control se plantea la eterna pregunta: 
¿Cómo se consigue crear un sistema experto? 
La respuesta, en su origen, es clásica: puesto 
que un sistema experto es un programa de or¬ 
denador, para realizarlo habrá que utilizar un 
lenguaje de programación. 

Si se responde un poco más en profundi¬ 
dad la respuesta hay que realizar algunos matices. Obviamente 
hace falta un lenguaje de programación, pero habrá unos lengua¬ 
jes que se adapten mejor a nuestras necesidades que otros; inclu¬ 
so se pueden utilizar herramientas más evolucionadas que los len¬ 
guajes clásicos, aunque estén basados en ellos. 

Basándose en los diversos niveles de software se han creado 
y diferenciado tres herramientas distintas que posteriormente se 
analizarán: los lenguajes de propósito general, los sistemas esque¬ 
letos y los sistemas conchas. Cada uno de ellos va aumentando 
en sencillez de utilización para el usuario, pero, a su vez, va per¬ 
diendo generalidad en sus aplicaciones. 



Niveles de Software 


La figura 1 muestra los niveles en que se divide el software 
que se necesita para resolver un problema mediante el hardware ■ 
de un ordenador. En la parte superior de la figura se refleja el pro¬ 
blema al que se enfrenta el experto en la materia, una parte del 





Situación real 




M Figura i—Los seis niveles de software posibles entre el problema 
real y el hardware del ordenador. 


mundo real; cuando se desea resolver dicho problema todo lo que 
observamos es cómo el experto maneja los datos de entrada y a 
partir de ellos llega a unas conclusiones. Lo que no se aprecia son 
los modelos mentales, las reglas de decisión y las estrategias que 
usa el experto cuando decide qué hacer en una determinada si¬ 
tuación particular. Este tipo de conocimiento es el siguiente esca¬ 
lón en la resolución de cualquier situación y es realmente lo más 
imprescindible. 

Por otra parte, independientemente del software que se utili¬ 
ce, todos los sistemas expertos dependen en el fondo del hard¬ 
ware del ordenador. La parte física del mismo es, al fin y al cabo, 
la encargada de manejar en último término toda la información en 
forma de códigos binarios, una larga serie de ceros y unos que 
el ordenador convertirá en respuestas físicas discretas. Este es el 
nivel inferior del software denominado lenguaje máquina. 

El nivel inmediatamente superior es el programa que dirige 
y direcciona las operaciones fundamentales del ordenador: el sis- 
lema operativo; se encarga de controlar las sentencias del lengua¬ 
je máquina. Suele estar escrito en lenguaje máquina o, reciente¬ 
mente, impreso en hardware dentro de un chip. 


Introduciéndonos ya en lo que es propiamente la programa¬ 
ción, casi toda ella se realiza en los denominados lenguajes de 
alto nivel. Los más conocidos son Basic, Cobol, Pascal, Fortran, 
Forth C, etc. Sin embargo, los programadores en inteligencia arti- 
licial utilizan fundamentalmente dos lenguajes- L1PS y PROLOG. 
1,1SP consiste en un conjunto de instrucciones que facilitan la crea¬ 
ción de programas que manejan listas, mientras que el PROLOG 
facilita el trabajo con expresiones lógicas. Ambos lenguajes son 
muy útiles por su carácter simbólico, mientras que los otros tra¬ 
bajan mejor con cálculos numéricos. 

justo por encima de los lenguajes de alto nivel se encuentran 
los entornos de programación. Dichos entornos suelen estar aso¬ 
ciados con un determinado lenguaje y contienen un conjunto de 
instrucciones escritas en dicho lenguaje, muy útiles para ciertas 
tareas de programación. Para los conocedores de lenguajes es¬ 
tructurados se pueden comparar con las subrutinas. 

Las herramientas son el quinto nivel en la figura 1. Estas he¬ 
rramientas se han creado para ayud ir al rápido desarrollo de los 
sistemas expertos Los aspectos más importantes que presentan 
son las estrategias de control, representación del conocimiento e 
inferencia comunes a la mayoría de los sistemas expertos. La ra¬ 
zón de una herramienta de este tipo es similar a las de una car¬ 
pintería: en vez de crear una nueva para cada tipo de mueble, se 
utilizan aquellas que nos han sido, útiles en anteriores ocasiones. 
Por supuesto, se debe usar la herramienta más apropiada para 
cada situación; cada una de ellas está especialmente diseñada 
para un trabajo en particular. 

Cuando se combina una herramienta con el conocimiento so¬ 
bre un tema específico, el resultado es un sistema experto basado 
en el conocimiento (nivel 6). Dicho sistema, si está bien desarro¬ 
llado, presenta la misma capacitación que el experto en dicho 
tema. 


De los lenguajes a los sistemas concha 

En general los lenguajes son más flexibles, pero más difíciles 
de usar en la creación y puesta a punto de un prototipo rápida¬ 
mente. Sólo cuando se necesita una aplicación muy particular o 
cuando el programador está muy bien preparado se construyen 
sistemas basados en LISP o PROLOG. Los sistemas conchas son 
menos flexibles, ya que llevan incorporado un particular sistema 
de control. Como consecuencia, si se tiene una herramienta apro¬ 
piada a nuestro problema, el desarrollo es muy rápido, e incluso 
personas con muy poca experiencia pueden crear pequeños pero 
muy útiles sistemas basados en el conocimiento. 
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En la figura 2 se presenta una vista general de los sistemas y 
lenguajes más conocidos. Los sistemas esqueleto o entornos se si¬ 
túan a mitad de camino entre los lenguajes y los sistemas concha, 

y sus características son una mezcla de flexibilidad y facilidad de 
utilización. 


Lenguajes 


Entornos 


S. conchas 
herramientas 



LISP 


PROLOG OPS 5 KEE EMYLIN 

INTERLISP LOOPS S.l. 

ART M.l. 

TIMM 

INSIGHT 


M Figura 2.—De los lenguajes de propósito general (LISP, PROLOG) a 
las herramientas más especificas. EMYCIN, SI ,... 


LISP es un lenguaje puro, mientras que PROLOG o INTERLISP 
están más cerca de los entornos. OPS 5, desarrollado por la Car- 
negie-Mellon University, sería propiamente un entorno; contiene 
un determinado sistema de control de las reglas, pero es bastante 
flexible. KEE es una herramienta o sistema concha, pero híbrida, 
es decir: puede optar por diversos controles y formas de repre¬ 
sentar el conocimiento; sin embargo, es muy difícil de utilizar. Por 
último EMYCIN, SI, etc., son muy fáciles de usar, pero se ajustan 
a un tipo específico de sistemas expertos. 

La figura 3 introduce una nueva complejidad en el análisis. 
Los lenguajes de programación en Inteligencia Artificial suelen 
ser LISP o PROLOG, pero es cierto que un sistema experto se pue¬ 
de escribir en Fortran o Pascal, por ejemplo. ¿Cuáles son las ven¬ 
tajas y los inconvenientes de su utilización 9 Los lenguajes de In¬ 
teligencia Artifical tienen unas características que les posibilitan 
el manejo de símbolos, mientras que los lenguajes convenciona¬ 
les trabajan mejor con números. Es mucho más conveniente, por 
tanto, tener herramientas o entornos programados internamente 
en lenguajes LISP o PROLOG que en lenguajes clásicos. 

La más clara desventaja para los "especializados" se presenta 
en que son menos conocidos y están menos extendidos que los 



M Figura 3—Estructura tridimensional de los lenguajes, las herramien¬ 
tas y los sistemas operativos en que trabajan. 


clásicos lenguajes de cuarta generación: mientras que casi todos 
los ordenadores tienen implantados FORTRAN y PASCAL, pocos 
de ellos tienen LISP o PROLOG. Muchos de los sistemas concha 
están, por tanto, escritos en PASCAL, lo que facilita su implanta¬ 
ción en toda clase de ordenadores, aunque al final sean menos efi¬ 
caces. 

Otro problema radica en el modo ineficaz en que los siste¬ 
mas operativos convencionales traducen el LISP a lenguaje má¬ 
quina, lo que provoca la lentitud de trabajo de muchos sistemas 
expertos. El futuro más próximo es la construcción de máquinas 
cuyo sistema operativo esté escrito en LISP. 

El estudio de los lenguajes de programación no es tarea de 
este libro y por su importancia e interés será objeto de otro vo¬ 
lumen de la B.B.I., pero sí queremos ofrecer una pequeña intro¬ 
ducción a las características más sobresalientes de los más impor¬ 
tantes. 


Se puede decir que el lenguaje LISP es el único utilizado pol¬ 
los americanos dentro de la inteligencia artificial. LISP proviene 
de List Processing Languaje; fue creado por John McCarthy en 
1958 y es, por lo tanto el más antiguo de los lenguajes en uso des¬ 
pués del FORTRAN. Su autor resumió en 1978 sus características 
más importantes: 

• Trabaja con expresiones simbólicas más que con números; 
esto es, los bits de la memoria y los registros pueden ser 
ocupados por símbolos arbitrarios y no sólo por operado¬ 
res aritméticos. 

• Procesamientos de listas; representación de los datos en lis¬ 
tas estructuradas dentro de la memoria 

• Estructura de control basada en la composición de funcio- ( 
nes básica; para formar otras más complejas. 

• Utilización de la Recursividad como una forma de escribir 
procesos y resolver problemas. 

• Representación interna de los programas escritos en LISP 
como un conjunto estructurado de listas. 

• La función EVAL, escrita a su vez en LISP, sirve como un 
intérprete del mismo y una definición formal del lenguaje. 

La conclusión más importante que se deduce es que no exis¬ 
ten diferencias esenciales entre los datos y las sentencias del pro¬ 
grama, es decir: un programa LISP puede usar unos datos que, a 
su vez, son otro programa LISP. Esta característica se traduce en 
la facilidad de modificar y ampliar un programa LISP. En conse¬ 
cuencia, el sistema experto asociado es capaz, por una parte, de 
modificarse a voluntad y, por otra, de diferenciar claramente el 
control y las reglas, aunque en el fondo ambas cosas sean progra¬ 
mas LISP. 

Existen muy pocas funciones básicas en LISP; todas las de¬ 
más se desarrollan a partir de éstas. Partiendo de la unidad fun¬ 
damental, la lista (que a su vez se compone de unidades indivi¬ 
sibles denominadas átomos) se crea la red del programa. Dicha 
red se construye mediante los nudos CONS. Cada átomo tiene aso¬ 
ciado una lista de propiedades que contiene información sobre el 
átomo: nombre, valor y cualquier otra propiedad que se desee. 
Los nudos CONS son una estructura de datos dinámica que se 
compone de dos campos (Fig. 4), cada uno de los cuales apunta 
hacia otro dato. Estos encadenamientos son fácilmente modifica- 
bles 

El manejo de estas listas se realiza mediante las siguientes fun¬ 
ciones: 
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M Figura 4.—La representación del conocimiento en LISP se suele rea¬ 
lizar mediante árboles o gratos de relaciones. Dichos gratos se re¬ 
presentan mediante listas, fácilmente codificables en memoria. 
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• CAR 


Proporciona el valor del primer elemento de una 
lista: 


CAR (Come Juan Patatas) = "Come" 

• CDR Da el valor de la lista sin el primer elemento: 

CDR (Come Juan Patatas) = (Juan Patatas) 


• CONS Junta dos expresiones pára formar una lista: 


CONS 

CONS 


COME (JUAN) = (COME JUAN) 
átomo lista 
LUIS ( ) = (LUIS) 

átomo lista 
vacía 


• ATOM Analiza si una estructura es lista o átomo; si es lista 

devuelve el valor (False) 

• EQUAL Proporciona el valor (True) si las dos expresiones 

son iguales. 


La programación en LISP se lleva a cabo construyendo fun¬ 
ciones muy sencillas que realizan unas determinadas tareas y lue¬ 
go agrupando las mismas para completar el trabajo global. 

El LISP no ha evolucionado mucho a lo largo de los últimos 
años debido a su carácter experimental que ha tenido hasta aho¬ 
ra, y a sus características propias; sin embargo, en el cuadro de 
la figura 5 se pueden apreciar las tendencias que ha seguido. 


PROLOG 

PRLOG, abreviatura de PROgraming lenguaje for LOGic, fue 
desarrollado inicialmente por Colmeraver y P. Roussel en 1972 en 
la Universidad de Marsella. 

PROLOG es un lenguaje de programación que implementa 
una versión simplificada del cálculo de predicados y utiliza un len¬ 
guaje lógico. Ha sido últimamente muy popularizado debido a su 
inclusión dentro del programa sobre quinta generación de orde¬ 
nadores que llevan a cabo los japoneses; también se está utilizan¬ 
do en los programas de Inteligencia Artificial que están siendo 
desarrollados por ingleses y franceses. 

Para programar en PROLOG se siguen los siguientes pasos: 

l 2 — Especificar algunos hechos y relaciones. 







f Figura 5.—E! desarrollo del lenguaje LISP se ha producido durante 
los últimos años, pero las diferencias no son demasiado grandes. 















2° — Especificar unas reglas sobre dichos hechos y relacio¬ 
nes. 

3. 2 — Hacer preguntas sobre los mismos. 

Por ejemplo: 

Ama (Carlos Ana) 

Ama (Pepe Julia) 

Ama (Gustavo Merche) 

Ahora, si preguntamos: 

? Ama (Pepe Julia) 

PROLOG responderá 
SI. 

En este ejemplo tan trivial, "Ama" es un predicado que indica 
una relación entre Carlos y Ana. 

Aunque PROLOG no incorpora toda la lógica que se necesita 
en el cálculo de predicados, su sintaxis es mucho menos comple¬ 
ja que la mayoría de los lenguajes normales de potencia compa¬ 
rable. Un lenguaje no puede ser estrictamente lógico: necesita 
algunos códigos básicos que controlen los aspectos de procedi¬ 
miento de las operaciones; esto, y en el grado mínimo, es lo que 
incorpora Prolog. De esta forma, en PROLOG se dice al ordenador 
en un lenguaje declarativo "qué" tiene que hacer y él se encar¬ 
gará de "cómo 11 hacerlo. Este es el aspecto más sobresaliente que 
incorpora PROLOG y lo que le diferencia de los demás lenguajes 
de programación. 

POPLOG 

Es una combinación de LISP, PROLOG y POP-11 introducidos 
en un mismo paquete; cuando se compila es más rápido que LISP 
o PROLOG incorporando además las ventajas de ambos sistemas. 

Es el sistema que está desarrollando IBM para sus aplicaciones in¬ 
ternas. 


Sistemas esqueleto o entomos de programación 

Sobre un sistema experto ya construido y bien probado se re¬ 
coge el mayor número de elementos compatibles con otros, for¬ 
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mando así un sistema esqueleto. Por ejemplo, la forma de repre¬ 
sentar el conocimiento, el control de las reglas, la inferencia, etc., 
representan el esqueleto del antiguo sistema experto. 

Cuando los creadores de un sistema experto pionero sobre 
diagnóstico médico (MYC1N) acabaron su trabajo se dieron cuen¬ 
ta que lo podían separar en dos partes bien diferenciadas; la base 
de conocimientos, donde se contenía toda la información sobre 
enfermedades infecciosas y que era específico de esta aplicación, 
y el motor de inferencia, un control “backward chaining" de pro¬ 
pósito general que bien podía ser utilizado por otras personas para 
crear otro sistema experto de parecidas características, pero so¬ 
bre un tema completamente distinto (Fig. 6). 



EXPERTO USUARIO 

O INGENIERO 
DEL CONOCIMIENTO 


Figura 6—Arquitectura de un sistema esqueleto: incluye el motor de 
ffiSOS inferencia y los subsistemas de adquisición, explicación e interface 
con el usuario . 


EMYCIN es una parte de MYCIN que recoge todo excepto la 
base de conocimientos, pero que contiene todo lo necesario para 
razonar sobre una base de conocimientos y responder a las con¬ 
sultas del usuario. No es, por tanto, un lenguaje de propósito ge¬ 
neral que se ajuste completamente a los requerimientos del sis- 
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tema experto, sino que al utilizar reglas O-A-V, usar la lógica mo- 
dus ponens y el motor de inferencia "backward chaining" sólo se 
puede adaptar a un tipo concreto de sistemas expertos, los de 
diagnosis fundamentalmente. 

Casi todos los sistemas esqueletos o entornos de programa¬ 
ción han ido apareciendo asociados a un sistema experto concre¬ 
to, al cual se le ha suprimido la parte de la base de conocimien¬ 
tos. La figura 7 representa la evolución de diversos sistemas en 
entornos de programación y su desarrollo a lo largo de los últi¬ 
mos años. v 



/ Figura Z— Desarrollo a lo largo del tiempo de los sistemas expertos 
y los sistemas esqueletos a que han dado lugar. 


Como se ha observado, el utilizar parte de algo ya creado es 
una buena solución, pero sin embargo, no está exenta de ciertos 
problemas, sobre todo si se quiere aplicar en tareas distintas a las 
concebidas para el sistema original. Este sería el caso de utilizar 
EMYCIN (diagnosis fundamentalmente) para crear un sistema ex¬ 
perto de ayuda a la planificación (EGERIA). 

Los principales problemas son: 

— El armazón del antiguo sistema puede resultar inapropia¬ 
do para la nueva tarea a realizar. 

— La estructura de control puede no encajar perfectamente 
en la forma de realizar inferencias que se desea. 

— El lenguaje antiguo puede resultar inapropiado. 

— Puede existir en el sistema un conocimiento previo sobre 
el control que no se necesite. 


Sistemas conchas o herramientas 

Son sistemas desarrollados a partir de lenguajes de propósito 
general que proporcionan mayor potencia para la creación de los 
sistemas expertos. Incorporan muchas facilidades sobre inferen¬ 
cia y control y agilizan enormemente la creación del sistema. 

Los expertos en Inteligencia Artificial, o Ingenieros del Cono¬ 
cimiento, estudiando el tipo de problemas a los que más fecuen- 
temente se enfrentan los profesionales de diversos campos han 
identificado tres estrategias de resolución, bien definidas y clara¬ 
mente diferenciadas. Son la diagnosis o prescripción, la planifica¬ 
ción y el diseño. En la figura 8 se pueden observar las caracterís¬ 
ticas de cada estrategia y el tipo de problemas a los que se en¬ 
frenta. Una vez que los pioneros definieron estos tres tipos, los sis¬ 
temas conchas que se han construido o se están construyendo se 
diseñan fundamentalmente para una de estas aplicaciones o, a lo 
sumo, para dos de ellas y sólo permiten el desarrollo de sistemas 
expertos cuya tarea se enclave dentro de los sistemas resolubles 
por dichas estrategias. 

Ciertas técnicas de representación del conocimiento (de in¬ 
ferencia o las estrategias de control) son en muchos casos espe¬ 
cíficas de una aplicación; por ejemplo, para la planificación, lo más 
normal es utilizar “forward chainning 1 ' (encadenamiento hacia ade¬ 
lante) en vez de "backward chainning", pero, sin embargo, otras, 
como por ejemplo los factores de certidumbre (centainty factors) 
pueden ser utilizadas en más de una aplicación, estando, por tan¬ 
to, incorporadas en la mayoría de los sistemas conchas. En gene¬ 
ral problemas de un tipo particular llevan asociadas herramientas 
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Tipo de problema: Diagnosis/Prescripción Planificación Diseño 
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construidas con una determinada forma de representación, infe¬ 
rencia y control. 

Los problemas o paradigmas más fáciles de resolver son los 
de Diagnosis y prescripción y en la actualidad la mayor parte de 
los sistemas concha comerciales (Fig. 9) están preparados para es¬ 
tas aplicaciones; únicamente los más complejos son capaces de 
atacar los problemas de planificación y, hoy por hoy, herramien¬ 
tas comerciales que ayuden a crear sistemas inteligentes en di¬ 
seño no existen. 



O 

M Figura 9.—Herramientas comerciales más usuales y tipos de proble¬ 
mas a los que se enfrentan. 
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Comercialmente los sistemas concha se dividen en tres ca¬ 
tegorías: 

• Herramientas para pequeños sistemas. Pueden trabajar so¬ 
bre ordenadores personales. Son diseñadas para facilitar el 
desarrollo de sistemas que contengan menos de 400 reglas. 

• Herramientas para grandes sistemas específicos. Pueden 
trabajar sobre máquinas L1SP (ordenadores especiales) o 
en grandes ordenadores y están diseñadas para crear sis¬ 
temas expertos que contengan entre 100 y varios miles de 
reglas, aunque estén restringidos hacia la resolución de un 
único tipo de problemas. 
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Figura 10.a).—Características de los sistemas concha más comunes 
en función de la representación del conocimiento. 
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• Herramientas para grandes sistemas. Pueden trabajar sobre 
máquinas LISP o en grandes ordenadores y están diseña¬ 
das para crear sistemas que contengan entre 500 y varios 
miles de reglas; pueden incluir las características necesa¬ 
rias para la resolución de distintos tipos de problemas. 

En la figura 10 se intenta dar una vista general de las diferen¬ 
cias que presentan varios sistemas conchas pertenecientes a las 
tres categorías anteriores; se puede apreciar cómo al ir aumen¬ 
tando la potencia aumentan las posibilidades de poder utilizar el 
conjunto de representación del conocimiento, inferencia y control 
que mejor se adapta al problema. 
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M Figura 10.b).—Características de los sistemas concha más comunes 
en función de los motores de inferencia. 
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CREACION DE UN SISTEMA EXPERTO 



través de este capítulo intentaremos dar una 
idea del proceso real que se sigue en la cons¬ 
trucción de un sistema experto pequeño, basa¬ 
do en la utilización tanto de las técnicas de in¬ 
teligencia artificial como de las herramientas 
que se han puesto al servicio de los ingenieros 
del conocimiento. 

La aplicación y el tipo de conocimiento se 
deben ajustar a los modelos ya estudiados de 
forma que su análisis sea menos complejo; problemas cuya reso¬ 
lución implique engorrosos cálculos o procesos iterativos tendrán 
probablemente mejor solución en la ya muy probada programa¬ 
ción clásica, y el coste, por otra parte, será sensiblemente inferior. 

Con el problema ya delimitado, los siguientes pasos se enca¬ 
minarán a determinar el tipo apropiado de herramienta necesaria 
para atacarlos, desde la utilización de lenguajes de propósito ge¬ 
neral como LISP o PROLOG a los sistemas conchas, pasando por 
los sistemas esqueletos o entornos. La elección de uno u otro no 
sólo depende de aspectos técnicos, sino también de recursos hu¬ 
manos y en último término, aunque son al final los que priman, los 


recursos económicos. 

La última etapa del desarrollo pasa forzosamente por la cons¬ 
trucción de un modelo, reducido del sistema que se quiere im¬ 
plantar; con dicho modelo a escala se experimentará y resolverán 
las primeras dificultades, sirviendo de campo de pruebas del de¬ 
sarrollo final. Una vez suficientemente probado se van aumentan¬ 
do sus prestaciones, y por tanto su complejidad, y sufrirá diver¬ 
sos procesos de realimentación y mejora hasta su instalación final. 










Primeras consideraciones 

Hasta ahora se han considerado sinónimas las acepciones 
“sistemas expertos" y "sistemas basados en el conocimiento" 
(Knowledge systems), pero en los sistemas pequeños esto no es 
del todo cierto. Los gráficos de la figura 1, que relacionan el nú¬ 
mero de personas que conocen un tema con lo que sabe cada 
una de esas personas sobre dicho tema en tres situaciones dis¬ 
tintas, muestra cómo en algunas de dichas situaciones o no existe 
el experto o todos son expertos. Es decir, aquellos sistemas ex- 




Tipo C: Todos saben resolver el problema. 
Todos expertos. 


Bueno , 


Malo 


M Figura 1.—Diferentes tipos de "profundidad del conocimiento" en un 
problema en función del número de expertos que conocen dicho 
problema. 
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pertos que contengan el conocimiento de los problemas del ter¬ 
cer tipo de la figura 1 no modelan realmente al experto humano, 
sino que sólo contienen un tipo de conocimiento. 

Si se construye un sistema experto que ayude a decidir el 
tipo de los seguros, la cuantía de los mismos y los bienes que cu¬ 
bre, no se puede decir que el conocimiento que posee, necesario 
para realizar estas funciones, sea el de un experto, sino más bien 
se le debe denominar sistema basado en el conocimeinto. Por otra 
parte están, por ejemplo, los grandes programas de inteligencia 
artifical como DENTRAL y MYCIN que asesoran y resuelven ca¬ 
sos médicos muy complejos y donde realmente ha sido necesa¬ 
rio recurrir a verdaderos especialistas para poder introducir, en 
unos cuantos miles de reglas y hechos, todo el saber que posee 
la humanidad en dichos campos científicos. Estos últimos progra¬ 
mas sí pueden ser denominados "sistemas expertos". 

Los sistemas expertos "pequeños" tienen una concepción dis¬ 
tinta a la de los grandes sistemas; las personas que utilizan estos 
programas no tienen por qué ser ingenieros de conocimiento, sino 
que normalmente, serán personas próximas al problema. En el 
ejemplo anterior (aquel que ayudaba en la determinación del se¬ 
guro más apropiado) el supervisor del programa deberá ser el 
agente de seguros y, por lo tanto, todo pequeño sistema experto 
será eficiente y tendrá éxito si es verdaderamente sencillo en su 
utilización. 

Como conclusión: los sistemas pequeños son normalmente 
sistemas basados en el conocimiento y su característica funda¬ 
mental es la sencillez de programación, manejo y modificación. 


Pasos a seguir , 

A la hora de decidirnos por el tema de un sistema experto pe¬ 
queño hubiéramos podido optar por algunos muy complejos, con 
los cuales se pudiera vislumbrar la potencia de estos programas, 
pero en beneficio de una mayor claridad hemos opiado por un 
tema de conocimiento general como es la elección del viaje en 
una aqencia de turismo' Es en realidad un sistema basado en el 
conocimiento, pues no necesita un experto en su realización y re¬ 
suelve problemas que cualquiera puede solucionar. 

Para su construcción los ingenieros del conocimiento deben 
seguir los siguientes pasos: 

1. Seleccionar una herramienta y tener en mente el tipo de es¬ 
trategia capaz de enfrentarse al problema. 

2. Identificar el problema y analizar el conocimiento que se 
vaya a incluir en el sistema. 
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3. Diseñar el sistema. Inicialmente implica construir uno con 
lápiz y papel mediante la utilización de diagramas de bloques, ma¬ 
trices y pequeños conjuntos de reglas. 

4 Desarrollar con el sistema concha seleccionado un prototi¬ 
po. Escribir la base de conocimientos y probarla en un número am¬ 
plio de casos. 

5. Ampliar y modificar el programa hasta que funcione tal y 
como queremos que lo haga. 

6. Mantener y poner al día el sistema según se necesite. 

Paso 1: Selección de la herramienta 

Las herramientas (o sistemas conchas) pequeñas son menos 
restrictivas en sus aplicaciones que las grandes. Si un programa 
necesita sólo 100 reglas su programador no demanda una serie 
de características que exigiría si dicho programa constara de 1.000 
reglas, por el simple motivo que 100 reglas son relativamente fá¬ 
ciles de controlar con la cabeza, mientras que si son 1.000 no hay 
persona que pueda trabajar con ellas. 

Por esta razón todas las herramientas pequeñas se adaptan 
bien y fácilmente a cualquier problema, siempre que pertenez¬ 
can al tipo de diagnosis y prescripción. En este caso se pueden 
utilizar cualquiera de las dos herramientas ejemplo del capítulo 
anterior (ver fig. 10 del capítulo 6); M.l o Personal Coñsultant. Am¬ 
bas representan el conocimiento mediante reglas 1F-THEN, y su 
motor de inferencia está basado en "Backward chainning" o (en¬ 
cadenamiento hacia atrás). Miníenla que u.'.'a;t-nio;: . ¡ 

vendida por Teknowledge Inc. Auqnue es muy 
cara, está bien diseñada y es muy fácil de usar. Admite toda clase 
de problemas que impliquen consultas del tipo diagnosis/solu¬ 
ción o prescripción y posee unas funciones que la hacen muy 
apta para ser manejada por toda clase de usuarios. 

Una vez decididos por M.l y el tipo de estrategia de resolu¬ 
ción que esto implica se debe confirmar que nuestro problema 
reúne las siguientes características; 

• El tiempo que debemos tardar en resolverlo debe estar nor¬ 
malmente entre los 15 y 30 minutos. Si es menos de 10 el 
problema es muy sencillo, y si se tarda más de 30 implica 
demasiado conocimiento y será muy lento. 

• No debe tener que examinar diagramas o cualquier con¬ 
tacto físico; será tal que pueda ser normalmente resuelto a 
través de una conversación telefónica. 

• Asimismo el proceso de resolución se podrá llevar a cabo 
mediante una serie de reglas y, como mucho, unos pocos 


cálculos. Si la solución requiere muchos cálculos es mejor 
la programación tradicional como, por ejemplo, una hoja de 
cálculo electrónica. 

• El conjunto de posibles soluciones finales no debe sobre¬ 
pasar unas pocas docenas. Si dichas soluciones son más de 
50 habrá, probablemente, otras herramientas más aptas que 
las utilizadas por I.A. 

El conjunto de estas normas reduce considerablemente el nú¬ 
mero de posibles temas a considerar. En el caso de la agencia de 
turismo, el cliente suele explicar su caso y elegir el viaje en unos 
20 minutos y no se precisan muchos cálculos matemáticos, quizá 
unas sumas y multiplicaciones para conocer los precios exactos 
aplicando diversas tarifas. A través del teléfono es posible contar 
todo lo referente al viaje y el conjunto de soluciones básicas no 
sobrepasa la docena y media. Si bien es cierto que dentro de cada 
solución básica (por ejemplo, apartamento en la playa) existen 
muchas variantes, ésta es la que en principio se buscaba, y deli¬ 
mitará enormemente el problema. 

Paso 2: Identificación y representación del conocimiento 

Consiste en la explicitación de cada uno de los factores que 
concurren en la solución del problema, es decir, es el conjunto de 
datos iniciales que debe conocer el agente de turismo para po¬ 
der decidir el tipo de viaje que más conviene a cada situación. 

Los factores que concurren en el problema 
cialmente a seis; motivo, fecha de viaje, dinero, número de perso¬ 
nas, lugar de residencia y edad. 

• Mi ¿Cuál es el motivo del viaje?, es uno de los facto¬ 
res más destacados y puede tomar los siguientes valores 
discretos: 

Descanso. 

Diversión. 

Deporte. 

Turismo. 

• Temporada en la que se pretende realizar 
el viaje: sólo se tendrán en cuenta las estaciones 

Verano (Junio-Septiembre). 

Invierno (Diciembre-Febrero). 

Primavera, Otoño (Marzo-Mayo, Octubre-Noviem¬ 
bre). 
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• Dinero. Cantidad de dinero que se piensa gastar en el via¬ 
je de una forma global: 

Normal (inferior a 75.000 pts/persona). 

Superior (más de 75.000 pts/persona). 

• Número de personas. Indica de alguna forma la preferen¬ 
cia o necesidad de optar por un tipo de viaje u otro; se com¬ 
pone de: 

Parejas. 

Familia. 

Grupos. 

• Lugar de residencia. Un factor poco indicativo por una par¬ 
te, pero muy exclusivo o limitativo por otra: 

Ciudad. 

Campo. 

Costas. 





• Edad. La edad suele conllevar un tipo de viaje distinto. Se 
compone de: 


Jóvenes (<30) 

Adultos (30<edad<60) 

Ancianos (>60) 

Hay que hacer notar que no todos los factores precedentes 
tienen la misma importancia y así deberían figurar en el sistema 
experto, pero por simplicidad a todos les será asignado el mismo 
valor. El lector, por otra parte, debe abstraerse del ejemplo parti¬ 
cular y generalizar mediante el mismo el concepto de sistemas ba¬ 
sados en el conocimiento. 

Una vez determinados los factores, la regla general que re¬ 
sulta es de la forma: 

Si (1) el motivo es. * 

(2) la fecha del viaje es. * 

(3) el dinero disponible.* 

(4) el número de personas es. * 

(5) el lugar de residencia. * 

(6) la edad es de... * 

Entonces se recomienda.** 

El siguiente paso será rellenar estos huecos. 


Paso 3: Diseño del sistema 

Inicialmente se limita el conjunto de soluciones a 10; luego, 
en la fase de ampliación y mejora, se podría llegar hasta un nú¬ 
mero aproximado de 40. Con estas primeras 10 soluciones se pue¬ 
de crear la matriz de la figura 2, donde en abcisas situamos las con¬ 
diciones o factores de entrada y en ordenadas las soluciones re¬ 
comendadas. 

M.l, como trabaja con "backward chainning”, requiere un fin 
del cual partir; éste es "viaje propuesto” y lo indicamos con: 

Goal = viaje-propuesto 
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Con esto le decimos que tiene que determinar el viaje-pro¬ 
puesto y él buscará siempre llegar a ello. Una vez completada la 
matriz de la figura 2 se ha finalizado el análisis del conocimiento; 
la primera regla puede ser: 


Motivo = Diversión 

and 

Fecha-viaje = Verano 

and 

Dinero = Normal 

and 

Personas = Familia 

and 

Lugar-resid = Ciudad 

v or 

Lugar-resid = Campo 

and 

Edad = Adultos 



Then viaje-propuesto = Playa-Apartamento-España. 

Para ilustrar cómo trabaja M.l y las facilidades de comunica¬ 
ción con el usuario que presenta, podemos construir un prototipo 
con esta única regla. Primeramente, y trabajando con un IBM-PC 
y un procesador de textos como puede ser Wordstar o cualquier 
otro, creamos un fichero donde escribimos el "Goal" y la regla nú¬ 
mero 1. La forma de escritura es idéntica a como se ha realizado 
arriba. Cerramos el fichero y vamos al programa principal M.l, 
desde donde llamamos al fichero creado anteriormente. 

M.l empieza comprobando el fin (Goal). Observa si en su me¬ 
moria activa consta este dato; si no lo encuentra prosigue la eje¬ 
cución del programa buscando alguna regla que concluya con 
viaje-propuesto. Como encuentra la que le acabamos de introdu¬ 
cir empieza a chequear las cláusulas "if' o antecedentes de dicha 
regla. El primer antecedente es "Motivo" Busca en su memoria 
de trabajo la información de ese campo; como no la encuentra 
mira si alguna regla concluye con un consecuente "Motivo", lo que 
no ocurre, ya que el fichero contiene una única regla. 

M.l resuelve el conflicto de la única manera posible: pregun¬ 
tando por el dato que le hace falta: 

What is the valué of: Motivo? 

(¿Cuál es el valor de "Motivo”?) 

Se puede contestar lo que se desee, pero si la respuesta no 
es "Diversión” recibiremos un mensaje de M.l diciendo: 

viaje-propuesto was songht, but no valué was concluded. 

(he buscado la solución pero no he encontrado ninguna). 

Si se contesta con "Diversión" y a todos los otros campos co¬ 
rrectamente la solución será: 
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viaje-propuesto=Playa—Apartamento—España. 

Este sencillo programa cualquier persona que conozca algún 
lenguaje de programación lo podría realizar fácilmente, pero le se¬ 
ría mucho más difícil crear uno que pudiera trabajar con cualquier 
número de reglas, hiciera las preguntas apropiadas y llegara a la 
solución correctamente. 

El prototipo completo se compondrá de las siguientes reglas, 

algunas de las cuales se incorporan para hacer al sistema más aa- 
tractivo de cara al usuario: 


regla 1 


regla 2 


if 

Motivo = Tranquilidad 

or 


Motivo = Paz 

or 


Motivo = Sosiego 

or 


Motivo = Descansar 

or 

then 

Motivo = Descanso 


if 

Motivo = Esquiar 

Motivo = Jugar al tenis 

or 

then 

Motivo = Deporte 



Estas reglas permiten al usuario responder de forma más na¬ 
tural a las preguntas del ordenador, que, por otra parte, se pue¬ 
den estructurar de forma distinta a la que llevaba inicialmente; así 
cuando le falte el dato del factor "Motivo" preguntará 

Cuestión (Motivo) = “¿Cual es el motivo de sus vacaciones?" 

De igual forma el usuario dispone en todo momento de las po¬ 
sibles respuestas a cada pregunta: 

legalvals (motivo) = tranquilidad, paz, sosiego, descansar, des¬ 
canso, esquiar, jugar al tenis, deporte, di¬ 
versión, turismo. 


regla 3 

if 

Fecha = Otoño 




Fecha = Primavera 



then 

Fecha-viaje = Primavera-Otoño 


regla 4 

if 

Fecha = Junio 

or 



Fecha = Julio 

or 



Fecha = Agosto 

or 



Fecha = Septiembre 



then 

Fecha-viaje = Invierno 


regla 5 

if 

Fecha = Dic 

or 



Fecha = Enero 

or 



Fecha = Febrero 



then 

Fecha-viaje = Invierno 


regla 6 

if 

Gastos =75.000 pts/persona 



then 

Dinero = Normal 
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regla 7 
regla 8 
regla 9 

regla 10 
regla 11 


regla 12 


regla 13 


regla 14 


regla 15 


if 

Gastos >75.000 pts/persona 


then 

Dinero = Superior 


if 

Edades <30 


then 

Edad = Joven 


if 

Edades>30 

and 


Edades <60 


then 

Edad = Adulto 


if 

Edades >60 


then 

Edad = Anciano 


if 

Motivo = Diversión 

and 


Fecha-viaje = Verano "• 

and 


Dinero = Normal 

and 


Personas = Familia 

and 


Lugar-res = Campo 

or 


Lugar-res = Ciudad 

and 


Edad = Adultos 


then 

Viaje-propuesto = Playa-Apartamento-España 

if 

Motivo = Diversión 

and 


Fecha-viaje = Verano 

and 


Dinero = Superior 

and 


Personas = Pareja 

and 


Lugar-res = Campo 

or 


Lugar-res = Ciudad 

and 


Edad = Adultos 


then 

Viaje-propuesto = Playa-Hotel-España 


if 

Motivo = Descanso 

and 


Fecha-viaje = Verano 

or 


Fecha-viaje = Invierno 

and 


Dinero = Normal 

and 


Personas = Pareja 

or 


Personas = Grupo 

and 


Lugar-resid = Ciudad 

and 


Edad = Jóvenes 

or 


Edad = Adultos 


then 

Viaje-propuesto = Montaña-España 


if 

Motivo = Deporte 

and 


Fecha-viaje = Invierno 

and 


Dinero = Normal 

and 


Personas = Pareja 

or 


Personas = Grupo 

and 


Lugar-res = Ciudad 

or 


Lugar-res = Costa 

and 


Edad = Jóvenes 


then 

Viaje-propuesto = Esquí-Espafia 


if 

Motivo = Deporte 

and 


Fecha-viaje = Invierno 

and 


Dinero = Superior 

and 


Personas = Grupo 

and 


Lugar-res = Ciudad 

or 


Lugar resid = Costa 

and 


Edad = Jóvenes 



regla 16 

then 

Viaje-propuesto = Esquí-Extranjero 


if 

Motivo = Descanso 

and 



Fecha-viaje = Invierno 

and 



Dinero = Normal 

and 



Personas = Pareja 

and 



Lugar-res = Ciudad 

or 



Lugar-res = Campo 

and 



Edad = Ancianos 

Edad = Adultos 

or 

regla 17 

then 

Viaje-propuesto = Playa-Canarias 


if 

Motivo = Turismo 

and 



Fecha-viaje = Pri-Oto 

and 



Dinero = Normal 

and 



Personas = Pareja 

Edad = Adultos 

and 

regla 18 

then 

Viaje-propuesto = Visita-grandes-ciudades 


if 

Motivo = Turismo 

and 



Dinero = Superior 

and 



Personas = Pareja 

Edad = Adultos 

and 

regla 19 

then 

Viaje-propuesto = Países-exóticos 


if 

Motivo = Turismo 

and 



Fecha-viaje = Pri-Oto 

and 



Dinero = Normal 

and 



Personas = Pareja 

Edad = Adultos 

and 


then 

Viaje-propuesto = Tour-autobús 

Motivo = Descanso 


regla 20 

if 

and 



Fecha-viaje = Pri-Oto 

and 



Dinero = Superior 

and 



Personas = Pareja 

Edad = Adultos 

Edad = Ancianos 

Viaje-propuesto = Crucero-mar 

and 

or 


then 



Paso 4: Desarrollo con el sistema concha de un prototipo 

Llegados a este punto sólo tenemos que escribir la base de 
conocimientos anterior y el sistema concha M.l se encarga del res¬ 
to: maneja las reglas y elige las que tiene que aplicar en cada 
caso, pregunta cuando desconoce algún factor y es capaz de mos¬ 
trarnos cómo ha llegado a esa solución o por qué, en un momento 
dado, hace una pregunta determinada. 

Estas dos últimas características son de gran ayuda e impor¬ 
tancia para el encargado de poner a punto el programa, facilitán¬ 
dole la depuración y eliminación de errores del sistema. 
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Paso 5: Ampliación y modificación 

La facilidad de ampliar una base de conocimientos debe ser 
una de las características más importantes de los sistemas con¬ 
chas. En nuestro caso se pueden escribir hasta 200 reglas en la 
base de M.l, con lo cual se podrían completar todos los casos que 
no se han introducido en el prototipo. 

En el ejemplo de la agencia de viajes se ha concedido un fac¬ 
tor de importancia, o de verosimilitud, al resultado de cada regla 
de 1.0, lo que no es en todos los casos ©ierto; se deberán introdu¬ 
cir en cada caso los factores de certeza correspondientes. 



Paso 6: Puesta al día y revisión 

Es sólo una extensión del paso 5 y consiste en adaptar la base 
de conocimiento a las situaciones cambiantes que concurren en 
el sistema experto. 

Aunque el ejemplo era realmente simple, con él nos hemos 
podido dar una idea del sistema utilizado en estos pequeños sis¬ 
temas basados en el conocimiento. 


: 



s muy difícil intentar describir cuál va a ser el 
futuro de una rama de la ciencia que se carac¬ 
teriza por su constante evolución y por la facili¬ 
dad con que cambian sus fundamentos. 

Sin embargo, aunque sea comentando gran¬ 
des tendencias, sí que se puede orientar hacia 
donde apuntan los proyectos de investigación 
que se realizan en la actualidad y que, a buen 
seguro, representan el futuro de todo el sector. 


Actualmente en Estados Unidos se han definido dos tenden¬ 


cias muy diferentes sobre cómo interpretar la filosofía de utiliza¬ 
ción y desarrollo de los sistemas expertos. 

Por un lado se encuentran los defensores del formalismo y la 
lógica como pilares de su desarrollo. . 

Son científicos que pretenden comprender el mundo median¬ 
te la lógica. Intentan formalizar todo lo que ocurre en la vida. Los 
límites de los sistemas expertos, en este sentido, se hallarán don¬ 
de la lógica resulte insuficiente para representar la realidad. Es de¬ 
cir: si se pudiera representar matemáticamente el hecho "el lector 
se está comiendo un flan mientras lee el libro", éste podría ser in¬ 
troducido en el ordenador y, por tanto, manejado como informa¬ 
ción conocida. El paradigma de estos científicos podría ser: "TODO 


COMIENZO DE ESTUDIO DEBE EMPEZAR POR LA SINTAXIS". 

Esta tendencia se encuentra ubicada en las universidades de 
la costa Oeste Americana como Stanford. 

Por otro lado se encuentran los científicos que propugnan co¬ 


menzar "entendiendo" el mundo antes de intentar formalizarlo. 


Ellos opinan que aunque resulte muy complicado entender los 
procesos, una vez conseguida esta comprensión es más fácil plas¬ 
mar las relaciones en un lenguaje formal. 


116 


117 





Para estos pensadores lo importante es el significado, la SE¬ 
MANTICA, antes que la sintaxis. Así, un paso anterior al intentar 
representar que "el lector se está comiendo un flan mientras lee 
el libro” sería comprender realmente lo que esto significa e inten¬ 
tar introducir esa información en la representación utilizada. 

Esta tendencia se encuentra sobre todo en las universidades 
de la costa Este Americana, como, por ejemplo, el M.I.T. (MASSA- 
CHUSETTS INSTITUTE OF TECHNOLOGY) o YALE. 

Como paradigma se podría concluir: "LO QUE INTERESA SON 
LOS CONCEPTOS”. 

A la hora de condensar las tendencias, Tom Alexander las de¬ 
fine como los «zarrapastrosos» (este) y los «pulcros» (oeste). 



La quinta generación de ordenadores 

Referido al futuro de los sistemas expertos habría que comen¬ 
tar, sin falta, el famoso proyecto QUINTA GENERACION DE ORDE¬ 
NADORES. 

En octubre de 1981 Japón anunció que, mediante la creación 
de un proyecto informático que tendría una duración de diez años, 


pretendía crear un nuevo modelo de ordenador que consiguiera 
revolucionar el mundo del tratamiento de la información. 

Pese a que no se han conseguido todavía todos los resulta¬ 
dos esperados, el proyecto está obteniendo unos avances signi¬ 
ficativos en ese área y, además, ha logrado que otros países se in¬ 
teresen lo suficiente por el tema como para empezar sus propias 
investigaciones. 

Analicemos brevemente lo que se pretende conseguir en el 
proyecto de quinta generación, paso a paso. 

• RAPIDEZ. Se pretende conseguir que los ordenadores fun¬ 
cionen más rápidamente, es decir, que sean capaces de 
procesar más instrucciones e información que los ordena¬ 
dores actuales en el mismo tiempo. 

Esto se intenta mediante unos CHIPS más rápidos con 
capacidad de proceso, es decir, de realizar operaciones bá¬ 
sicas. 

• TRABAJO CON LOGICA SIMBOLICA. Actualmente, los or¬ 
denadores funcionan con estructuras fundamentalmente 
numéricas. Aunque también manejan símbolos distintos de 
los números, todavía resulta algo farragosa la utilización de 
letras y caracteres no numéricos en programas de todo tipo. 

Se pretende, con este impulso, crear un software (es¬ 
tructuras de programas, programas en general) capaz de 
permitir manejar en el futuro cualquier tipo de información 
de una manera óptima. 

Esto permitiría una mejorasustancial en el proceso del 
conocimiento, tema que está directamente relacionado con 
los sistemas expertos. 

• UTILIZACION DEL LENGUAJE NATURAL. Desde luego, esta 
posibilidad no se conseguirá en un 100% hasta dentro de 
muchos años. Sin embargo, muchos tipos limitados de len¬ 
guaje natural se pueden conseguir sin demasiados pro¬ 
blemas. 

El proyecto de ordenadores de la quinta generación 
propone la consecución de esta característica tanto en con¬ 
cepto de comprensión del usuario (que el ordenador sea 
capaz de comprender lo que el usuario le mande en un len¬ 
guaje común), como en generación de mensajes (que el or¬ 
denador sea capaz de generar la información que suminis¬ 
tra al usuario utilizando el lenguaje del propio usuario) in¬ 
cluso de viva voz, es decir, que el ordenador sea capaz de 
hablar. 

• ARQUITECTURA TIPO PARALELO. Hasta ahora los ordena¬ 
dores trabajan de una forma secuencial, es decir, el micro- 
procesador realiza las tareas asignadas una por una. 




En el plan de ordenadores de la quinta generación se preten¬ 
de conseguir que existan muchos microprocesadores que reali¬ 
cen muchas tareas a la vez, pero sin que dependan siempre de 
un mismo "jefe". Esto resulta muy complicado y costará también 
mucho el conseguirlo. En cualquier caso, el proyecto está supo¬ 
niendo y supondrá un gran avance en la técnica informática. 
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menudo el escollo más importante que debe su¬ 
perar una nueva tecnología para su implanta¬ 
ción se encuentra en la propia sociedad huma¬ 
na. El hombre necesita tiempo para adaptarse a 
cambios que varían sus costumbres, y más si és¬ 
tos vienen a cuenta de "el futuro". De por sí, la 
informática ha supuesto una transformación tan 
radical de la sociedad humana que para muchas 
personas está siendo imposible seguir el ritmo. 
Como parte integrante de esta revolución informática se en¬ 
cuentra la Inteligencia Artificial. De reciente conocimiento a nivel 
general se encuentra en estos momentos en plena "digestión so- 


Mientras que en el mundo de la técnica y la gestión se ha aco¬ 
gido con curiosidad, muchos otros presentan ya los primeros sín¬ 
tomas de preocupación. Preguntas como ¿Adonde vamos a lle¬ 
gar? están a la orden del día. 


Pero realmente: ¿Sabemos adonde vamos a llegar? ¿T<•ruanos 
seguridad de que el problema no se nos escapará do la:: manos? 
Si se plantea la cuestión con un poco de visión futuiinla ,• m i-, .roí:: 
taremos? 


Podemos tenerla seguridad de que los faioco.vi inda m 

tarde o temprano (y probablemente má:; leni| nam. • ... i . 

encontrarán totalmente automatizado:: Ida> .|in< i. di.p. m. 

se necesitará personal humano pata imliznilo' m pa ..11. d u 

los. Conseguir este antiguo suoflo l im 11 , n i> • (• .i pn . .1 ■.. , 

plantea dos grandes problema:: 
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• ¿Puede ocurrir que un "error” a gran escala pueda llegar a 
paralizar la actividad mundial? Resulta claro el considerar 
este problema como ficticio, precisamente por la enorme 
capacidad de operación y trabajo autónomo que pueden 
conseguir los ordenadores. 

• ¿Será capaz la sociedad de aceptar un cambio radical en 
sus estructuras y la llegada de "la sociedad del ocio”? Tal 
vez sea el proceso más difícil de alcanzar por su compli¬ 
cación. 

El ser humano debe asumir lo que en un principio re¬ 
sulta fácil: hay que transformar el hombre-trabajador en 
hombre-cultural. 

Asimismo, inherente a todo este proceso, se encuentra otro 
gran riesgo. Tal y como se está llevando el desarrollo informático 
actualmente, de manera anárquica, mucha gente se plantea el pro¬ 
blema de mantener intacta la libertad de operación, actuación y 
pensamiento que exigen los derechos naturales del hombre. Real¬ 
mente la impresión general existente sobre la informatización es 
una "pérdida de libertad". Esto puede resultar engañoso por cuan¬ 
to lo que se critica puede ser el "no poder hacer lo que no debo". 

El planteamiento anterior, la pérdida de libertad, tiene sus raí¬ 
ces en la siguiente pregunta: ¿Puede un ordenador llegar a deci¬ 
dir de forma global sobre algo? El problema de los temas de de¬ 
cisión es importante. Nuestro mundo se vanagloria de ordenado¬ 
res con mayor rapidez, capacidad de raciocinio y decisión, tal vez 
sin sopesar la necesidad de controlar su evolución. Se necesita¬ 
rían unas reglas básicas de la informática, al estilo de las de ro- 
bótica propuestas por Isaac Asimov (*). 

En cualquier caso no es motivo de gran preocupación, sino 
de establecer un simple control. Mientras tanto, la evolución con¬ 
tinúa y serán los hombres que estudien estos temas los que ten¬ 
drán en sus manos el poder de decidir sobre toda la sociedad. 


Aunque no sea éste el motivo más importante para muchos, 
cuantos más españoles trabajen sobre el tema más se nos podrá 
oír en el futuro. Por eso hay que animar a todos los interesados a 
que investiguen, estudien y propongan sus soluciones. Tanto en 
Inteligencia Artificial como en otras ramas en ellos se encuentra 
nuestro futuro. 


(*) Conocido escritor de obras de divulgación científica e histórica y de no¬ 
velas de ciencia-ficción. En estas últimas ha tocado muy a menudo el tema de los 
robots inteligentes, desarrollando las que se denominó "Leyes de la robótica" (ver, 
por ejemplo, "Yo robot" en la colección Nebulae de Edhasa), que han sido adop¬ 
tadas y utilizadas, incluso, por otros autores del género Estas tres leyes son: 

1. Un robot no puede dañar a un ser humano, ni por su inacción permitir que sufra 
daño. 

2. Un robot debe obedecer las órdenes que le son dadas por un ser humano, ex¬ 
cepto cuando estas órdenes están en oposición con la primera ley. 

3. Un robot debe proteger su propia existencia hasta donde esta protección no en¬ 
tre en conflicto con la primera o segunda ley. 
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1 igual que ordenadores y paquetes de 
aplicación quedan rápidamente obsoletos 
como consecuencia de la aparición en el 
mercado de otros mejores en un espacio 
de tiempo increíblemente corto, lo mismo 
le ha ocurrido ya a la programación clá¬ 
sica: en el futuro ya no se utilizarán los 
programas, sino los sistemas expertos. 
Los ordenadores de la quinta generación serán capaces 
de “hablar” sin problemas con el usuario y de progra¬ 
marse automáticamente a partir tan sólo de las indicado- , 
nes del usuario sobre el problema a resolver. 

Ambas situaciones, que comienzan ya a ser realidad en 
los países más avanzados, son tan sólo algunas de los as¬ 
pectos de la llamada inteligencia artificial, un nuevo reto 
para el hombre de nuestro siglo. 



395 pts. 

(incluido IVA) 








